<?php // Полная загрузка сервисных книжек, создан 2025-01-05 12:44:55
global $wpdb2;
global $failure;
global $file_hist;
///// echo '<H2><b>Старт загрузки</b></H2><br>';
$failure=FALSE;
//подключаемся к базе
$wpdb2 = include_once 'connection.php'; ; // подключаемся к MySQL
// если не удалось подключиться, и нужно оборвать PHP с сообщением об этой ошибке
if (!empty($wpdb2->error))
{
///// echo '<H2><b>Ошибка подключения к БД, завершение.</b></H2><br>';
$failure=TRUE;
wp_die( $wpdb2->error );
}
$m_size_file=0;
$m_mtime_file=0;
$m_comment='';
/////проверка существования файлов выгрузки из 1С
////файл выгрузки сервисных книжек
$file_hist = ABSPATH.'/_1c_alfa_exchange/AA_hist.csv';
if (!file_exists($file_hist))
{
///// echo '<H2><b>Файл обмена с сервисными книжками не существует.</b></H2><br>';
$m_comment='Файл обмена с сервисными книжками не существует';
$failure=TRUE;
}
/////инициируем таблицу лога
/////если не существует файла то возврат и ничего не делаем
if ($failure){
///включает защиту от SQL инъекций и данные можно передавать как есть, например: $_GET['foo']
///// echo '<H2><b>Попытка вставить запись в лог таблицу</b></H2><br>';
$insert_fail_zapros=$wpdb2->insert('vin_logs', array('time_stamp'=>time(),'last_mtime_upload'=>$m_mtime_file,'last_size_upload'=>$m_size_file,'comment'=>$m_comment));
wp_die();
///// echo '<H2><b>Возврат в начало.</b></H2><br>';
return $failure;
}
/////проверка лога загрузки, что бы не загружать тоже самое
$masiv_data_file=stat($file_hist); ////передаем в массив свойство файла
$m_size_file=$masiv_data_file[7]; ////получаем размер файла
$m_mtime_file=$masiv_data_file[9]; ////получаем дату модификации файла
////создаем запрос на получение последней удачной загрузки
////выбираем по штампу времени создания (редактирования) файла загрузки AA_hist.csv, $m_mtime_file
///// echo '<H2><b>Размер файла: '.$m_size_file.'</b></H2><br>';
///// echo '<H2><b>Штамп времени файла: '.$m_mtime_file.'</b></H2><br>';
///// echo '<H2><b>Формирование запроса на выборку из лога</b></H2><br>';
////препарируем запрос
$text_zaprosa=$wpdb2->prepare("SELECT * FROM `vin_logs` WHERE `last_mtime_upload` = %s", $m_mtime_file);
$results=$wpdb2->get_results($text_zaprosa);
if ($results)
{ foreach ( $results as $r)
{
////если штамп времени и размер файла совпадают, возврат
if (($r->last_mtime_upload==$m_mtime_file) && ($r->last_size_upload==$m_size_file))
{////echo '<H2><b>Возврат в начало, т.к. найдена запись в логе.</b></H2><br>';
$insert_fail_zapros=$wpdb2->insert('vin_logs', array('time_stamp'=>time(),'last_mtime_upload'=>$m_mtime_file,'last_size_upload'=>$m_size_file,'comment'=>'Загрузка отменена, новых данных нет, т.к. найдена запись в логе.'));
wp_die();
return $failure;
}
}
}
////если данные новые, пишем в лог запись о начале загрузки
/////echo '<H2><b>Попытка вставить запись о начале загрузки в лог таблицу</b></H2><br>';
$insert_fail_zapros=$wpdb2->insert('vin_logs', array('time_stamp'=>time(),'last_mtime_upload'=>0, 'last_size_upload'=>$m_size_file, 'comment'=>'Начало загрузки'));
////очищаем таблицу
$clear_tbl_zap=$wpdb2->prepare("TRUNCATE TABLE %s", 'vin_history');
$clear_tbl_zap_repl=str_replace("'","`",$clear_tbl_zap);
$results=$wpdb2->query($clear_tbl_zap_repl);
///// echo '<H2><b>Очистка таблицы сервисных книжек</b></H2><br>';
if (empty($results))
{
///// echo '<H2><b>Ошибка очистки таблицы книжек, завершение.</b></H2><br>';
//// если очистка не удалась, возврат
$failure=TRUE;
wp_die();
return $failure;
}
////загружаем данные
$table='vin_history'; // Имя таблицы для импорта
//$file_hist Имя CSV файла, откуда берется информация // (путь от корня web-сервера)
$delim=';'; // Разделитель полей в CSV файле
$enclosed='"'; // Кавычки для содержимого полей
$escaped='\
В процедуре Процедура НастроитьОтборСписка() в строке
Отбор = Список.Отбор.Элементы;
какое значение у Список?
НастройкаОтбораПоВладельцам.Вставить(«ПравоеЗначение» , СписокКонтрагентов);
СписокКонтрагентов это просто список значений заранее настроенный?
> Отбор = Список.Отбор.Элементы;
Список — реквизит формы, тип = ДинамическийСписок
> НастройкаОтбораПоВладельцам.Вставить(«ПравоеЗначение» , СписокКонтрагентов);
СписокКонтрагентов — тип = СписокЗначений
(0)
testplatform@1c.ru
часть этого уже реализовано на уровне платформы. См. команду ПараметрыВыбора. Причём она работает даже для тех объектов у которых формы списка не созданы. Эти параметры применяются на уровне платформы, нужно только в форме владельце их задать элементу в котором происходит выбор. Только у этого способа есть врождённые недостатки — отборы возможны только на равенство :(.
Самое хреновое в 8.2 — это отключенная возможность отборов по Критериям отборов в формах списков документов, как в 8.1. Такой мощный механизм, элементарно настраивался — и убрали…
(4) Именно отсутствие возможности проверки на равенство и сподвигло к созданию вышеприведенного кода.
При открытии формы выбора не происходит позиционирование на элементе.
(7) решается добавлением обработчика:
&НаКлиенте
Процедура ПриОткрытии(Отказ)
Если ТипЗнч(ЭтаФорма.ВладелецФормы) = Тип(«ПолеВвода») Тогда
Элементы.Список.ТекущаяСтрока = ЭтаФорма.ВладелецФормы.Значение;
КонецЕсли;
КонецПроцедуры
(8) Тип значения «ЭтаФорма.ВладелецФормы» — «ПолеФормы», пока для решения (7) использую «серверную» функцию 🙁
(9) извиняюсь. предусмотрел только случай, когда управляемая форма открывается из обычной. Рекомендацию в (8) снимаю.
То ли в 8.2.11 добавили, то ли я раньше не заметил, но через типовой механизм можно передавать отбор по списку:
Список = Новый СписокЗначений;
Список.Добавить(Значение1);
Список.Добавить(Значение2);
ПараметрыОтбора = Новый Структура(«Контрагент», Список);
ПараметрыОткрытия = Новый Структура(«Отбор», ПараметрыОтбора);
ОткрытьФорму(«Документ.РеализацияТоваровУслуг.Форма.ФормаВыбора», ПараметрыОткрытия, Элемент);
спасибо за полезную информацию!!!
в (11) указано более правильное решение, но все эти решения не правильные 🙂
Потому как при вводе по строке(без открытия формы) все эти отборы и способы не работают, поэтому если нужно реально ограничить список доступных элементов для выбора то либо стандартные «СвязьПараметровВыбора» либо как в 8.1 генерировать список значений программно и назначать его как списоквыбора для поля ввода.
Я вижу, что единственный правильный вариант в (11), а если нужно ещё и ограничить список при вводе строки, тогда можно указать связи параметров выбора (не подходит для случая с отбором, например, поле «владелец» «в списке»), или вообще запретить редактирование текста.
Кстати, я считаю, что нельзя жестко фиксировать отбор формы выбора. Нужно оставить пользователю возможность его отключить, так как, скорее всего, программист не всегда может предугадать, что в дальнейшем будет нужно выбрать пользователю. Другими словами, нужно оставить пользователю шанс на «если очень хочется, то можно» (т.е. дать управление в руки пользователя на вой страх и риск), что позволит в будущем обойтись без программирования в случае возникновения исключительной непредвиденной ситуации (если, конечно, такая ситуация не вызовет ошибок).
Для открытия списка документов с отбором я использовал такую конструкцию. Думаю она и для справочника подойдет.
Форма = ОткрытьФорму(“Документ.РасходнаяНакладная.Форма.ФормаСписка”); //Открываем форму списка документов
Отбор = Форма.Список.Отбор.Элементы.Добавить(Тип(“ЭлементОтбораКомпоновкиДанных”)); //Добавляем отбор
Отбор.ВидСравнения = ВидСравненияКомпоновкиДанных.Равно; //Как будем сравнивать
Отбор.Использование = Истина; // Устанавливаем галку использования
Отбор.ЛевоеЗначение = Список.Отбор.ДоступныеПоляОтбора.Элементы.Найти(“Контрагент”).Поле; //Выбираем по какому реквизиту будем делать отбор
Отбор.ПравоеЗначение = Объект.Контрагент; // И само значение отбора
(8) — а вот и не подходит)) у параметра «ЭтаФорма.ВладелецФормы» — Поля «Значение» нет… это я про УФ… ровно как и «Тип(«ПолеВвода»)» в отладчике говорит, что он Тип(«ПолеФормы»)… я пока новичек, но вроде как это понимаю…
Коллеги, а как в форму в качества параметра передать настройки сортировки, которые должны применяться к списку? Я хочу открыть форму выбора, в которой элементы будут отсортированы по определенному реквизиту.
(17) komratov, вот пример используемого мной кода для задачи добавления сортировки списка по заданному полю, причем сортировка должна быть обязательно первой. В процедуре «ПриСозданииНаСервере» формы списка:
Показать
Спасибо! Нагло пользуюсь вашим кодом, сейчас возникла необходимость использовать группы условий(например группа или), если я правильно понимаю, мне нужно доработать процедуру НастроитьСписокОтбора()? Может быть поддадите волшебного пендаля, в каком направлении двигать? Заранее спасибо!
Добрый день. Использование — код я поместил в обработчик НачалоВыбора, но не работает.
ругается:
{Документ.УПДК_РеализацияНедвижимости.Форма.ФормаДокумента.Форма(1971)}: Ошибка при вызове метода контекста (ОткрытьФорму)
http://v8.1c.ru/8.2/mngsrv/ws }val
http://v8.1c.ru/8.1/data/core }Value
ОткрытьФорму(«Справочник.УПДК_ВидыПравовыхДокументов.ФормаВыбора», ПараметрыОткрытия);
по причине:
Ошибка передачи данных между клиентом и сервером. Значение недопустимого типа.
по причине:
Ошибка преобразования данных XDTO:
Запись значения свойства ‘val’:
форма: Элемент
имя: {
по причине:
Ошибка преобразования данных XDTO:
Запись значения свойства ‘Value’:
форма: Элемент
имя: {
по причине:
Ошибка отображения типов:
Отсутствует отображение для типа ‘ПолеФормы’
Что-то много комментариев. Кто-нибудь уже написал про
Форма = ПолучитьФорму(…);
// Настройка формы
…
Форма.Открыть();
??
Просто в таком случае не надо перекурочивать сами формы выбора объектов, а только место вызова…