Создаем периодические реквизиты или привет из 1С 7.7

14.04.23

Разработка - Механизмы платформы 1С

Конечно же, платформа 1С:Предприятие 8 не поддерживает периодические реквизиты, в статье описано использование типовой методики периодических сведений в коробочных решениях от 1С.

Механизм периодических сведений не включен в БСП, но тем не менее используется в большинстве типовых решений 1С, прежде всего в ЗУП, и реже - в остальных (УТ, КА и т.д.). Он может быть полезен при добавлении своих "периодических" реквизитов в конфигурацию. В его состав входит всего четыре модуля:

  • РедактированиеПериодическихСведений
  • РедактированиеПериодическихСведенийВызовСервера
  • РедактированиеПериодическихСведенийКлиент
  • РедактированиеПериодическихСведенийКлиентСервер

На небольшом примере покажем, как добавить "периодический" реквизит в типовую конфигурацию. Предположим, мы ведем учет автомобилей в справочнике "Автомобили" и у этого справочника есть реквизит "Пробег", в котором фиксируется история пробега.

Начнем с регистра. Регистр будет иметь наименование ПробегАвтомобилей (оно произвольное). У регистра одно измерение Автомобиль с типом СправочникСсылка.Автомобили, ведущее. И ресурс Пробег, тип - числовой. Естественно, регистр периодический.

 

 

Далее, к регистру добавляем форму набора записей с наименованием РедактированиеИстории. Наименование должно быть именно таким, так как именно такая форма нужна типовому коду. У реквизита НаборЗаписей снимаем признак Основной реквизит, это нужно для работы отбора и добавляем следующий реквизит:

  • ОбъектВладелец с типом СправочникСсылка.Автомобили

На форму этот реквизит выносить не нужно, он используется в работе механизма для отбора.

Примерный вид формы:

 

 

 
 Код берем типовой

Код несложный, оставлю только несколько пояснений:

  • ПриСозданииНаСервере, заполняем набор записей из переданных в форму при создании параметров, там уже будет отбор по владельцу, т.е. будут сведения о пробеге только целевого автомобиля.
  • НаборЗаписейПриНачалеРедактирования, заполняем владельца записи набора регистра, т.е. автомобиль, заполняем период по-умолчанию.
  • НаборЗаписейПередОкончаниемРедактирования, предупреждаем пользователя, если он некорректно заполнил новую запись.
  • НаборЗаписейПриОкончанииРедактирования, упорядочеваем записи по дате при окончании редактирования.
  • КомандаОК, вызываем типовое оповещение о закрытии.

К слову сказать, форма совершенно шаблонная и, например, в ЗУП-е таких, почти одинаковых форм, 30 (тридцать).  Т.е. если в других ЯП используется наследование, у нас используется копи-паст.

Перейдем к адаптации справочника-владельца "периодического" реквизита. Форме элемента справочника Автомобили добавляем пять реквизитов:

  • ПробегАвтомобилей с типом РегистрСведенийМенеджерЗаписи.ПробегАвтомобилей
  • ПробегАвтомобилейНаборЗаписей с типом РегистрСведенийНаборЗаписей.ПробегАвтомобилей
  • ПробегАвтомобилейНаборЗаписейПрочитан с типом булево
  • ПробегАвтомобилейНоваяЗапись с типом булево
  • ПробегАвтомобилейПрежняя с типом Произвольный

Обратите внимание, все добавленные реквизиты имеют префикс ПробегАвтомобилей, он должен совпадать с наименованием регистра сведений, в котором хранится история "периодического" реквизита.

Больше всего здесь нас интересует реквизит ПробегАвтомобилей, именно он несет в себе полезную нагрузку. Выводим реквизит ПробегАвтомобилей.Пробег на форму, остальные реквизиты - служебные, они используются в работе механизма и на форме не отображаются.

 
 Код также берем типовой

Небольшие пояснения:

  • ПриСозданииНаСервере, читаем историю реквизита из регистра
  • ОбработкаОповещения, обновляем реквизит на форме
  • ПередЗаписьюНаСервере, записываем данные в регистр
  • ПробегИстория, открытие формы истории реквизита

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

 

 

По задумке разработчиков, в 8-й версии в форме элемента всегда редактируется последняя запись. В 7-й версии при редактировании значения периодического реквизита, новое значение добавлялось в историю автоматически с текущей датой. Чтобы воспроизвести такое поведение, можно поступить примерно так:

 
 Примерный код

Т.е., если значение поменялось, добавляем новую запись с текущей датой и выставляем признак новой записи в истину.

 

Спасибо, что дочитали до конца, если вы работали в семерке, уверен, на вашем лице улыбка.

Периодический реквизит

См. также

Механизмы платформы 1С Программист Стажер Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

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

23.06.2024    7520    bayselonarrend    20    

154

Механизмы платформы 1С Программист Стажер Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Пример использования «Сервисов интеграции» без подключения к Шине и без обменов.

13.03.2024    5970    dsdred    16    

80

Механизмы платформы 1С Программист Стажер Платформа 1С v8.3 Бесплатно (free)

Все мы используем массивы в своем коде. Это один из первых объектов, который дают ученикам при прохождении обучения программированию. Но умеем ли мы ими пользоваться? В этой статье я хочу показать все методы массива, а также некоторые фишки в работе с массивами.

24.01.2024    17815    YA_418728146    26    

71

Механизмы платформы 1С Программист Бесплатно (free)

Язык программирования 1С содержит много нюансов и особенностей, которые могут приводить к неожиданным для разработчика результатам. Сталкиваясь с ними, программист начинает лучше понимать логику платформы, а значит, быстрее выявлять ошибки и видеть потенциальные узкие места своего кода там, где позже можно было бы ещё долго медитировать с отладчиком в поисках источника проблемы. Мы рассмотрим разные примеры поведения кода 1С. Разберём результаты выполнения и ответим на вопросы «Почему?», «Как же так?» и «Зачем нам это знать?». 

06.10.2023    23789    SeiOkami    48    

135

WEB-интеграция Универсальные функции Механизмы платформы 1С Программист Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

При работе с интеграциями рано или поздно придется столкнуться с получением JSON файлов. И, конечно же, жизнь заставит проверять файлы перед тем, как записывать данные в БД.

28.08.2023    14785    YA_418728146    7    

166