<?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='\
хорошая идея, но не новая
(1). На новизну не претендую. Пример показывает саму возможность и как это реализовывается.
Я кстати тоже когда стало надо такую штуку сначала хотел сделать панелькой с вкладками, но потом решил на хтмл-е сделать.
http://infostart.ru/projects/4559/
Глянь, может для себя что-нибудь за идею возьмешь
Не подумай, что пиарю 🙂
(3). Как раз твой пример и натолкнул, но реализация в HTML мне не понравилась. Вообще ищу возможность добавлять стандартные контролы системы, вот тогда можно было бы развернуться. Пока не нашел.
Ну это нормальная ситуация, не нравится чужое, пиши свое 🙂
Ну это уж как говорится на вкус и цвет 🙂
(4) Мне кстати и самому (да и юзерам моим) сначала казалось, что как-то неудобно и непривычно, а щас ничо, говорят: «придешь, запустишь и прям работать охота» 🙂
по поводу контролов, я вот сейчас пытаюсь разработать с помощью Flash ActiveX, может кто знает, что это такое, так вот флеш мне дает графическое расширение, которое в 1с естс не развито (хотя это и не надо)…, идея такая существует доп. справочник контролов, который может генерить даже пользователь (естс ответственнй пользователь), при активации панели с использованием flash компоненты при помощи протокола xml предаются данные, ну а по ним строится интерфейсная модель, идея доходит до того, что можно подгружать интерактивную карту, на которой размещены области и объекты (города, контрагенты), таким образом путем активации объекта (тупо клик) можно выписать счет или оформить доставку, что то я нафлудил….
короче вопрос такой, скажите будет ли это иметь решение?… принимаются любые мнения…
Сейчас многие вещи частично или полностью делают с поддержкой веб интерфейса, ну и Flash там же. И вроде у 8.2 там тоже уже такой «вебный» интерфейс. Злые языки вообще поговаривают, что будущее за вебом 🙂
(7). С флешом тоже идея хорошая. Надо будет подумать
Очень полезная вещь, спасибо — сдеру завтра. Типовые интерфейсы конфигураций крайне перегружены, тогда как простым смертным пользователям 90% функций просто не нужны.
Эх, не забыть бы после завтра закачать… А то закачки на сегодня и завтра у меня уже запланированы, а как известно можно только 1 в день закачать, если рейтинг меньше 30…
Интерфейс развился и теперь есть 2 варианта: изначальный и узкий, в котором вкладки заменены на обычное подменю. Это продиктовано просьбами пользователей с широкоэкранными ноутами, а у них, как правило, ширина экрана делается в ущерб высоте. Этот вариант выложу немного позже, так как его надо выдрать из конфы.
Теперь немного о самой реализации построения. Был создан справочник «Интерфейсы», состоящий изназвания и табличной части с колонками Страница, Линия1, Линия2, Линия3, Действие. Соответственно последняя линия являлась кнопкой с действием, а предыдущие линии (если они есть) — подменю. Действие = имя процедуры в модуле формы. В справочние «Пользователи» так же была добавлена табличная часть «Интерфейсы» с колонками «Интерфейс» и «Активность». Таким образом пользователю можно сделать сборный интерфейс, состоящий из нескольких. Так же у пользователя был добавлен флаг «Узкий интерфейс».
Добавил форму из своей конфы и описание, что нужно для ее корректной работы. Соответственно изменил офисание.
Может кто знает, как можно основную менюху програмно прятать и показывать?
можно создать пустой интерфейс и переключатся на него
Да я и так пустой интерфейс подставляю. Хочется просто программно прятать основное меню там где «Файл» и т.д. и обратно отображать.
Добавлен вертикальный вид интерфейса.
(18) основываясь на вашем опыте и примере сделал собственную обработку и выложил ее сюда.
http://infostart.ru/projects/5781/
100 % совместима с Вашими обработками.
В вашей обработке добавил возможность хранения процедур в общем модуле.
Для этого использовал подсказку.
Изменения в коде следующие:
1. В процедуре «ПередОткрытием» заменяем
Новый Действие (Эл.Действие) на Новый Действие («КнопкаНажата»)
Процедура КнопкаНажата (Элемент)
Попытка
Выполнить (Элемент.Подсказка);
Исключение
КонецПопытки;
КонецПроцедуры;
Процедура ПередОткрытием (Отказ, СтандартнаяОбработка)
….
Для каждого Эл из Элементы Цикл
СтрокаКоманды = «СобытияИнтерфейса.» + Эл.Действие + «();»;
…
Лин3 = Лин2.Кнопки.Добавить ….
Лин3.Подсказка = СтрокаКоманды;
…
Лин2 = Лин1.Кнопки.Добавить ….
Лин2.Подсказка = СтрокаКоманды;
…
Лин1 = ЭлементыФормы[ ….
Лин1.Подсказка = СтрокаКоманды;
…
КонецПроцедуры
Соответственно все действия переносятся в общий модуль
«СобытияИнтерфейса» и к каждому действию добавляется «Экспорт»
Преимущества — возможность использовать в одной конфигурации несколько динамических интерфейсов, а действия изменять сразу для всех интерфейсов централизованно в одном месте.
(20). У меня все процедуры по интерфейсу хранятся в одном месте — общая форма «ОсновноеМеню». Если используется вертикальный интерфейс, то он все-равно обращается к процедурам формы «Основное меню». Эти же процедуры можно открыть из любого места конфигурации, то есть использование любых других видов интерфейсов так же возможно.
(7) Работа с Flash в 1С возможна! Постараюсь в ближайшие день — два выложить некий пример по работе с картами.
Большое спасибо. простой и ничего лишнего. спасибо за сэкономленное время.
Чето в 8.2 ошибки
(24) Он не предназначен для управляемых форм.
Да нет формы обычные просто под 8.2 сконвертировал
Странно. Мы конвертили — у нас все работало. Где ошибку выдает и какую?
Еще бы действия генерить прямо в справочнике интерфейсов, чтоб процедуры не дописывать при добавлении какого-то нового пункта меню. Тогда пользователи смогут делать менюшки сами без участия программиста
(28) Oleeeg, у себя уже дописал. Просто вписываю в «Действие» код вызова нужной формы. Сделать это несложно.