К вопросу об использовании подписок на события в типовых конфигурациях.

27.08.08

Разработка - Механизмы типовых конфигураций

Пришла вот такая хотелка {для УПП 1.2.17.3}:
"При вводе счет/фактуры выданной (если ранее уже была оплата) не подтягивается платежное поручение (его № и дата)."
Расшифровка: при вводе СФВ на основании Акта услуг, в котором указан счет (сделка), если по этому счету была платежка покупателя, ее дата/номер должна проставляться в СФВ.
Нет, проблем, ведь подписки придуманы именно для таких случаев, верно?
Заводим в конфу новую подписку, указываем источник - СФВ, событие - Заполнение. и обработчик с простеньким запросом:
Процедура ВводСФВНаОснованииАктаОбработкаЗаполнения(Источник, Основание) Экспорт
	Счет = Основание.Сделка.Ссылка;
	Если ЗначениеЗаполнено(Счет) Тогда
	Запрос = Новый Запрос;
		Текст = "ВЫБРАТЬ
		|	ЕСТЬNULL(ПлатежноеПоручениеВходящее.ДатаВходящегоДокумента, ПлатежноеПоручениеВходящее.Дата ) КАК ДатаПлатежноРасчетногоДокумента,
		|	ЕСТЬNULL(ПлатежноеПоручениеВходящее.НомерВходящегоДокумента, ПлатежноеПоручениеВходящее.Номер) КАК НомерПлатежноРасчетногоДокумента
		|ИЗ
		|	Документ.ПлатежноеПоручениеВходящее КАК ПлатежноеПоручениеВходящее
		|ГДЕ
		|	ПлатежноеПоручениеВходящее.РасшифровкаПлатежа.Сделка = &Сделка
		|";
		Запрос.Текст = Текст;
		Запрос.УстановитьПараметр("Сделка",Счет);
		Результат = Запрос.Выполнить();
		Если Результат.Пустой() Тогда
			Сообщить("Нет входящих платежных поручений по (сделке): "+Счет);
		Иначе
			Источник.ДатаНомерДокументовОплаты.Загрузить(Результат.Выгрузить());
		КонецЕсли; 
	Иначе
		Сообщить("Не заполнен Счет (Сделка) в "+Основание);
	КонецЕсли;
КонецПроцедуры


Запускаем, работает. Только почему-то в табличке появляется лишняя пустая строчка... Ёклмн!

Разбираемся. Оказывается, в СФВ в ПриОткрытии() уважаемая фирма вставила вот такую фигню:
Процедура ПриОткрытии()
...	
	Если ЭтоНовый() Тогда
...
		Если ДокументОснование <> Неопределено Тогда
			ЗаполнитьДатуИНомерВходящегоДокумента();
		КонецЕсли;
	КонецЕсли;
...
КонецПроцедуры


Сама вызываемая процедура
Процедура ЗаполнитьДатуИНомерВходящегоДокумента(ОбрабатываемыйДокументОснование = Неопределено)
Запрос = Новый Запрос;
Запрос.Текст = 
		"ВЫБРАТЬ
		|	НДСУчетРаспределенныхОплатПокупателей.ДокументОплаты,
		|	ЕСТЬNULL(НДСУчетРаспределенныхОплатПокупателей.ДокументОплаты.НомерВходящегоДокумента, НДСУчетРаспределенныхОплатПокупателей.ДокументОплаты.Номер) КАК НомерВходящегоДокумента,
		|	ЕСТЬNULL(НДСУчетРаспределенныхОплатПокупателей.ДокументОплаты.ДатаВходящегоДокумента, НДСУчетРаспределенныхОплатПокупателей.ДокументОплаты.Дата) КАК ДатаВходящегоДокумента
		|ИЗ
		|	РегистрНакопления.НДСУчетРаспределенныхОплатПокупателей.Обороты(, &КонецПериода, Период, СчетФактура В (&СписокОснований)) КАК НДСУчетРаспределенныхОплатПокупателей";
				   
	Если ОбрабатываемыйДокументОснование = Неопределено Тогда
		Запрос.УстановитьПараметр("СписокОснований", УчетНДС.УдалитьПовторяющиесяЭлементыМассива(ДокументыОснования.ВыгрузитьКолонку("ДокументОснование"),Истина));
	Иначе
		Запрос.УстановитьПараметр("СписокОснований", ОбрабатываемыйДокументОснование);
	КонецЕсли;
	
	Запрос.УстановитьПараметр("КонецПериода", Новый Граница(КонецДня(Дата),ВидГраницы.Включая));
	Выборка = Запрос.Выполнить().Выбрать();
	Пока Выборка.Следующий() цикл
		НовыйПРД = ДатаНомерДокументовОплаты.Добавить();
		НовыйПРД.ДатаПлатежноРасчетногоДокумента = Выборка.ДатаВходящегоДокумента;
		НовыйПРД.НомерПлатежноРасчетногоДокумента = Выборка.НомерВходящегоДокумента;
	КонецЦикла;
КонецПроцедуры

представляет собой маленький шедевр:

Ну, во-первых, то, что из трех колонок запроса используются только две,
факт, хоть и говорящий о качестве кода уважаемой, но прямо к теме не относится.
Во-вторых, то, что перед вызовом - единственном в конфигурации - проверяется условие
ДокументОснование <> 
,
а потом в теле процедуры предлагается
Если ОбрабатываемыйДокументОснование = 

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

В-третьих. Почему же эта процедура, предназначенная как раз для удовлетворения означенной хотелки,
выдает пустую строку?

Вот пример набора записей регистра по одному Акту:
1.
Формирование записей книги продаж 00000000001 от 31.01.2008 12:00:00
31.01.2008 12:00:00
Акт об оказании производственных услуг 00000000001 от 31.01.2008 9:22:15
<null>
288 693,23
2.
Регистрация оплаты от покупателей для НДС 00000000002 от 29.02.2008 12:00:00
07.02.2008 12:00:00
Акт об оказании производственных услуг 00000000001 от 31.01.2008 9:22:15
Платежное поручение входящее 00000000066 от 07.02.2008 12:00:00
288 693,23

Дата СФВ устанавливается не текущая, а дата Акта-основания. Наверное, это правильно,
но из регистра при этом выхватывается только первая запись, и в таблице запроса
получим строку с пустыми значениями даты и номера.

Ну, не знаю. Мне не хочется объяснять бухгалтерии, что платежка "не подтягивается"
потому, что хотя оплата и уже была, но ее еще не было, когда сформировали Акт.
Не потому, что это сложно. А потому, что это - отмазка. Потому, что бухгалтерии работать надо,
а не восхищаться изяществом методологической мысли уважаемой фирмы.
Да и какого фига? Какое нафиг изящество?
Вот мой запрос - он работает. Вот типовой - он дает пустую строку. КонецДискуссии.
Но и это - не отностся к теме статьи.

Темой статьи является замечательная особенность платформы -
используя механизм подписки на события, можно что-то изменить в алгоритме типовой конфигурации,
не ИЗМЕНЯЯ объектов. Так вот, оказывается, что можно, но с оглядкой. Потому, что
разработчики типовой кофигурации могут разместить первоначальное заполнение
в ПриОткрытии. И каждый раз(!), открывая форму, проверять, не в первый ли раз она открывается.
Я - оглянулся (не собирался, пустая строчка бросилась в глаза).
И ИЗМЕНИЛ модуль формы выданной фактуры:
//+ comment tango
// ЗаполнитьДатуИНомерВходящегоДокумента();
//- comment tango


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

Вступайте в нашу телеграмм-группу Инфостарт

Вы можете заказать платную адаптацию этой статьи под ваши задачи на «Бирже заказов».

  • 0% комиссии — оплата напрямую исполнителю;
  • Исполнители любого масштаба — от отдельных специалистов до команд под проект;
  • Прямой обмен контактами между заказчиком и исполнителем;
  • Безопасная сделка — при необходимости;
  • Рейтинги, кейсы и прозрачная система откликов.

См. также

Инструментарий разработчика БСП (Библиотека стандартных подсистем) Механизмы типовых конфигураций Программист 1С 8.3 1С:ERP Управление предприятием 2 Абонемент ($m)

Данное расширение — это механизм, сделанный при помощи двух модулей из БСП (3.1.11.415), который позволяет динамически добавлять команды (кнопки и не только при желании) на формы управляемого приложения без изменения конфигурации. На примере данного механизма удобно рассмотреть некоторые возможности для расширения функционала объектов, которые подключены к механизму библиотеки стандартных подсистем.

1 стартмани

20.03.2026    1637    InFlach    0    

6

Механизмы типовых конфигураций Программист Стажер 1С 8.3 1С:Зарплата и Управление Персоналом 3.x Бесплатно (free)

Интервальные регистры в 1С:ЗУП 3.1 заменяют тяжелые срезы последних, ускоряя отчеты по кадровым данным через интервалы ДатаНачала–ДатаОкончания. Разбираем отличия, примеры кода, плюсы и способы синхронизации.

12.03.2026    3192    AlexeyPROSTO_1C    4    

20

Механизмы типовых конфигураций Программист Стажер 1С 8.3 1С:Зарплата и Управление Персоналом 3.x Бесплатно (free)

Как в ЗУП работает механизм расстановки времени в регистрах сведений с помощью подписки на события?Рассматривается логика сдвигов для разных типов документов (прием, увольнение, отпуск) и дается инструкция по подключению нового регистра к этому механизму.

03.03.2026    1724    YA_1100893639    1    

7

Механизмы типовых конфигураций Программист 1С:Предприятие 8 1С:ERP Управление предприятием 2 Россия Бесплатно (free)

В статье рассматривается подход к программной модификации параметров команды внешней обработки заполнения объекта так, чтобы в момент вызова из формы объекта (табличной части документа) она использовалась для открытия вспомогательной формы диалога, а после закрытия вспомогательной формы диалога она использовалась для заполнения объекта (табличной части документа) уже на сервере с контекстом формы документа с использованием введенных данных во вспомогательной форме диалога.

11.08.2025    8563    user1988284    0    

23
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. tango 552 27.08.08 20:03 Сейчас в теме
спасибки, artbear.
на 30 просмотров 1+ = специфическая статья :)
ну, т.е. не для средних умов :)
2. poppy 01.09.08 22:55 Сейчас в теме
Правильно ли я поняла, что ты, tango, предлагаешь в СФ от 31.01 вписать ПП от 7.02?

Не я вляется ли таким образом оформленный документ прямым доказательством нарушения п.3 ст.168 НК?
3. tango 552 03.09.08 11:08 Сейчас в теме
ты неправильно поняла, поппи.
я - профессионал, а не любитель.
это значит, что поставленная передо мной задача будет выполнена.
а методологические сопли - для любителей.
только не путать любителей (ну, тех кто тащится от 1сных скриптов) с дилетантами.
4. ubertwoborg 03.09.08 13:33 Сейчас в теме
побольше такого пишите, человек
доставляет удовольствие читать людей, которые
а) умеют мыслить правильно
б) умеют эти мысли излагать так, чтобы их было приятно читать

плюсик вам от души
спасибо
5. palax 01.11.09 07:26 Сейчас в теме
tango вы прекрасны спору нет! Но вспомните себя когда вы только начинали.....Наверное над вами то же кто нибудь посмеивался...поэтому считаю из уважения к себе вам стоило бы в другом контексте рассматривать подобные случаи...по моему так правильнее. Спасибо и не обижайтесь!
6. tango 552 15.05.10 10:56 Сейчас в теме
(5) palax, поверьте, я не минусую перенумераторы :)
но это вы сравнили разработчиков типовых конфигураций 1С со студентами.
7. FlexL 29 24.05.10 22:48 Сейчас в теме
интересно ... и пример показал как использовать "подписку на событие" и бяку при которой может несработать ...так держать ;)
8. tango 552 04.11.10 13:40 Сейчас в теме
приятно. давно, и не вебинар, и не вообще как-нибудь круто, а плюсики приходят.
не приятно: причина сабжа актуальна.
:!: проги 1с не следуют правилам, декларируемым 1с
9. Поручик 4612 11.03.11 23:11 Сейчас в теме
(8) О сколько нам ошибок чудных.. С каждым релизом БП 2. убеждаюсь.
10. пользователь 27.09.12 12:55
Сообщение было скрыто модератором.
...
11. zakakvo 03.07.14 11:20 Сейчас в теме
До сих пор актуально, кстати ))) Спасибо, мил человек, помог мне сегодня!
12. tango 552 06.07.14 10:13 Сейчас в теме
(11) zakakvo, приходите еще
Для отправки сообщения требуется регистрация/авторизация