Ошибка если поле не заполнено 1с

В этой статье я рассмотрю основные механизмы платформы 1С 8.3, которые обеспечивают проверку заполнения реквизитов.

Проверка заполнения реквизита объекта 1С

У любого реквизита объекта 1С можно настроить проверку заполнения, когда нельзя сохранить новый элемент объекта, не заполнив этот реквизит. Выйдет ошибка.

Для того, чтобы у реквизита объекта осуществлялась проверка заполнения, достаточно в свойстве реквизита «Проверка заполнения» указать значение «Выдавать ошибку».

Проверка заполнения реквизита объекта 1С

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

Проверка заполнения реквизита объекта 1С

Данная проверка будет осуществляться независимо от того, сгенерирована эта форма платформой 1С 8.3 автоматически, или используется форма созданная разработчиком.

Проверка заполнения табличной части в 1С

Помимо реквизитов у объектов можно проверять заполнение табличной части.  Для этого у табличных частей объектов имеется свойство «Проверка заполнения», в которое также необходимо установить значение «Выдавать ошибку».

Проверка заполнения табличной части в 1С

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

Проверка заполнения табличной части в 1С

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

Проверка заполнения табличной части в 1С

Если мы хотим проверять реквизиты табличной части, то у них нужно заполнить аналогичное свойство.

Проверка заполнения программно в 1С

Иногда возникает необходимость проверить программно заполнение объекта в 1С. Для этих целей предназначен метод ПроверитьЗаполнение(), который имеется у большинства объектов 1С (справочники, документы и т.д.).

Например, во время программного создания элемента справочника, мы можем проверить заполнение реквизитов этого справочника, перед его записью.

НовОбъект = Справочники.Номенклатура.СоздатьЭлемент();
НовОбъект.Наименование = "Товар";
Если НовОбъект.ПроверитьЗаполнение() Тогда
    НовОбъект.Записать();
КонецЕсли;

В этом случае, элемент справочника не будет записан, если у него имеются реквизиты, у которых в свойстве ПроверкаЗаполнения установлено значение «Выдавать ошибку».

Иногда, нужно проверить заполнение реквизита, у которого в свойстве «Проверка заполнения» установлено значение «Не проверять».  Например, у реквизита Артикул справочника Номенклатура.

Проверка заполнения программно в 1С

Если нам нужно осуществлять проверку этого реквизита (например, по какой-то определенной логике), то необходимо в модуле объекта создать метод  ОбработкаПроверкиЗаполнения.

ОбработкаПроверкиЗаполнения в 1С

ОбработкаПроверкиЗаполнения в 1С

У этого метода, который является процедурой, имеется параметр ПроверяемыеРеквизиты. Этот параметр массив, в котором содержится список имен реквизитов, которые нужно проверять. Если в этот список мы добавим название реквизита, то при сохранении элемента будет осуществляться проверка на то, заполнен этот реквизит или нет.

Процедура ОбработкаПроверкиЗаполнения(Отказ, ПроверяемыеРеквизиты)
    ПроверяемыеРеквизиты.Добавить("Артикул");
КонецПроцедуры
Проверка заполнения программно в 1С

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

Например, удалим из проверяемых реквизит ПолноеНаименование.

Процедура ОбработкаПроверкиЗаполнения(Отказ, ПроверяемыеРеквизиты)
    Индекс = ПроверяемыеРеквизиты.Найти("ПолноеНаименование");

    Если Индекс <> 0 Тогда
        ПроверяемыеРеквизиты.Удалить(Индекс);
    КонецЕсли;

КонецПроцедуры

Тогда мы сможем спокойно записать элемент с незаполненным реквизитом ПолноеНаименование.

Проверка заполнения программно в 1С

Если мы хотим проверить программно, что заполнен реквизит табличной части объекта, то необходимо добавить этот реквизит в массив ПроверяемыеРеквизиты по такому формату: [НазваниеТабличнойЧасти].[НазваниеРеквизита] .

Например:

Процедура ОбработкаПроверкиЗаполнения(Отказ, ПроверяемыеРеквизиты)

    ПроверяемыеРеквизиты.Добавить("СписокСвойств.НазваниеСвойства");

КонецПроцедуры

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

Проверка заполнения программно в 1С

Проверка заполнения формы 1С

Иногда нужно проверить заполнение реквизитов формы.  Разберем небольшую задачу: будем на форме умножать два числа друг на друга, если они заполнены. Создадим на форме реквизиты  с типом Число — Множитель1, Множитель2 и Сумма. У реквизитов Множитель1 и Множитель2 установим в свойство «Проверка заполнения» значение «Выдавать ошибку».

Проверка заполнения реквизита объекта 1С

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

&НаКлиенте
Процедура Посчитать(Команда)

    Если ПроверитьЗаполнение() Тогда

        Сумма = Множетель1 * Множетель2;

    КонецЕсли;

КонецПроцедуры

Теперь мы не сможем посчитать сумму, если один из множителей не заполнен.

Проверка заполнения реквизита объекта 1С

Более подробно и основательно начальные вопросы программирования в 1С есть вы можете изучить в
Книга «Программировать в 1С за 11 шагов»

Изучайте программирование в 1С в месте с моей книгой «Программировать в 1С за 11 шагов»

Программировать в 1С за 11 шагов

Книга написана понятным и простым языком — для новичка.

  1. Книга посылается на электронную почту в формате PDF. Можно открыть на любом устройстве!
  2. Научитесь понимать архитектуру 1С;
  3. Станете писать код на языке 1С;
  4. Освоите основные приемы программирования;
  5. Закрепите полученные знания при помощи задачника.

О том как разрабатывать под управляемым приложением 1С, читайте в книге Книга «Основы разработки в 1С: Такси»

Отличное пособие по разработке в управляемом приложении 1С, как для начинающих разработчиков, так и для опытных программистов.

Основы разработки в 1С такси
  1. Очень доступный и понятный язык изложения
  2. Книга посылается на электронную почту в формате PDF. Можно открыть на любом устройстве!
  3. Поймете идеологию управляемого приложения 1С
  4. Узнаете, как разрабатывать управляемое приложение;
  5. Научитесь разрабатывать управляемые формы 1С;
  6. Сможете работать с основными и нужными элементами управляемых форм
  7. Программирование под управляемым приложением станет понятным

Промо-код на скидку в 15% — 48PVXHeYu

Эти книги, плюс книга по программированию оперативного учета имеются в едином комплекте: комплект книг по разработке в 1С.
Только для читателей моего блога,
промо-код на скидку в 300 рублей на весь комплект: blog


Если Вам понравился этот урок, был полезен или помог решить какую-нибудь проблему, то Вы можете поддержать мой проект, перечислив любую сумму
.

можно оплатить вручную:

Яндекс.Деньги — 410012882996301
Web Money — R955262494655

Вступайте в мои группы:

Вконтакте: https://vk.com/1c_prosto
Фейсбуке: https://www.facebook.com/groups/922972144448119/
ОК: http://ok.ru/group/52970839015518
Твиттер: https://twitter.com/signum2009

Механизм проверки заполнения позволяет автоматически проверить, заполнены ли указанные реквизиты объекта. Для этого нужно воспользоваться свойством ПроверкаЗаполнения, которое есть у реквизитов объектов конфигурации.

Если установить это свойство в значение «Выдавать ошибку», поле Поставщик в форме будет помечено как обязательное для заполнения. А при записи накладной платформа будет контролировать заполненность этого реквизита. Если реквизит окажется не заполнен, платформа выдаст автоматическое сообщение и запись накладной будет отменена.

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

  • Одно событие — ОбработкаПроверкиЗаполненияНаСервере — можно обработать в модуле формы.
  • Другое событие — ОбработкаПроверкиЗаполнения — можно обработать в модуле прикладного объекта.

У формы, как правило, есть основной реквизит (редактируемый объект) и могут быть реквизиты, не относящиеся к редактируемому объекту, а являющиеся лишь частью формы:

Поэтому серверное событие формы ОбработкаПроверкиЗаполненияНаСервере предназначено для проверки заполнения тех реквизитов формы, которые не относятся к редактируемому объекту. Это данные только формы, у формы могут быть свои причины и алгоритмы для проверки этих данных.

Напротив, событие объекта ОбработкаПроверкиЗаполнения предназначено для для того, чтобы проверить реквизиты основного реквизита формы.

Обработчики обеих событий имеют параметр ПроверяемыеРеквизиты, в который платформа передает массив имен тех реквизитов, которые подлежат проверке. Если после выхода из обработчика в этом массиве все еще останутся какие-то имена реквизитов — платформа выполнит автоматическую проверку оставшися реквизитов.

Поэтому существует несколько сценариев того, как разработчик может встроить свой алгоритм в механизм проверки заполнения:

  • самостоятельно проверить заполненность всех реквизитов и очистить массив ПроверяемыеРеквизиты, чтобы платформа не выполняла их проверку
  • проверить часть реквизитов самостоятельно, удалить их из массива ПроверяемыеРеквизиты, а оставшиеся оставить на проверку платформе
  • добавить в массив ПроверяемыеРеквизиты какие-то реквизиты, чтобы платформа проверила и их тоже
  • вообще отказаться от проверки заполненности реквизитов, очистив массив

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

Если Поставщик = Справочники.Поставщики.ПустаяСсылка() Тогда
    Сообщение = Новый СообщениеПользователю();
    Сообщение.Текст = "Необходимо заполнить поставщика!";
    Сообщение.Поле  = "Поставщик";
    Сообщение.УстановитьДанные(ЭтотОбъект);
    Сообщение.Сообщить();
    Отказ = Истина;
КонецЕсли;

// Проверка остальных реквизитов
// ..........

// Очистить массив проверяемых реквизитов, чтобы платформа
// не выполняла их автоматическую проверку
ПроверяемыеРеквизиты.Очистить(); 

Чтобы проверить лишь часть реквизитов, можно выполнить такой код:

Если Поставщик = Справочники.Поставщики.ПустаяСсылка() Тогда
    Сообщение = Новый СообщениеПользователю();
    Сообщение.Текст = "Необходимо заполнить поставщика!";
    Сообщение.Поле  = "Поставщик";
    Сообщение.УстановитьДанные(ЭтотОбъект);
    Сообщение.Сообщить();
    Отказ = Истина;
    // Удалить поставщика из массива проверяемых реквизитов
    ИндексПоляПоставщик = ПроверяемыеРеквизиты.Найти("Поставщик");
    Если ИндексПоляПоставщик <> Неопределено Тогда
        ПроверяемыеРеквизиты.Удалить(ИндексПоляПоставщик);
    КонецЕсли;
КонецЕсли;

Добавить в массив проверяемых реквизитов еще один реквизит можно следующим образом:

ПроверяемыеРеквизиты.Добавить("Комментарий");

А очистить массив проверяемых реквизитов, чтобы ничего не проверять ни самому, ни платформе, можно так:

ПроверяемыеРеквизиты.Очистить();

Вторым параметром в обработчиках этих событий является параметр Отказ. Если ему присвоить значение Истина, то после выхода из обработчика дальнейшая запись объекта будет отменена. Таким образом этот параметр нужно устанавливать в значение Истина тогда, когда ваш алгоритм приходит к выводу, что реквизит не заполнен. В этом случае запись объекта выполнена не будет.

Справка

ОбработкаПроверкиЗаполненияНаСервере(Отказ, ПроверяемыеРеквизиты)

УправляемаяФорма.ОбработкаПроверкиЗаполненияНаСервере(Отказ, ПроверяемыеРеквизиты)
  • Отказ. Тип: Булево. Признак отказа от записи. Если в теле процедуры-обработчика установить данному параметру значение Истина, то запись выполнена не будет. Значение по умолчанию Ложь.
  • ПроверяемыеРеквизиты. Тип: Массив. Массив путей к реквизитам, для которых будет выполнена проверка заполнения. Массив может быть модифицирован удалением или добавлением путей к необходимым реквизитам.

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

Позволяет разработчику самостоятельно реализовать проверку заполнения в обработчике события. При этом в обработчике можно полностью отказаться от системной обработки (очистив список проверяемых реквизитов), отказаться от проверки системой части реквизитов (выполнив проверку отдельных реквизитов особенным образом и исключив эти реквизиты из списка), а также добавить для проверки другие реквизиты, проверка которых не была указана.

Для формы документа, если при конфигурировании для документа свойство Проведение установлено в Разрешить, событие вызывается только при проведении. Если документ не проводится (свойство Проведение установлено в Запретить), то вызывается при записи.

ОбработкаПроверкиЗаполнения(Отказ, ПроверяемыеРеквизиты)

ДокументОбъект.ИмяДокумента.ОбработкаПроверкиЗаполнения(Отказ, ПроверяемыеРеквизиты)
  • Отказ. Тип: Булево. Если в теле процедуры-обработчика установить данному параметру значение Истина, то будет выполнен отказ от продолжения работы после выполнения проверки заполнения. Значение по умолчанию Ложь.
  • ПроверяемыеРеквизиты. Тип: Массив. Массив путей к реквизитам, для которых будет выполнена проверка заполнения. Массив может быть модифицирован удалением или добавлением путей к необходимым реквизитам.

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

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

Процедура ОбработкаПроверкиЗаполнения(Отказ, ПроверяемыеРеквизиты)

    // Проверим заполненность реквизита «Покупатель»
    Покупатель = ПроверяемыеРеквизиты.Найти("Покупатель");

    Если Не ЗначениеЗаполнено(Покупатель) Тогда
        
        // Если он не заполнен, сообщим об этом пользователю
        Сообщение = Новый СообщениеПользователю();
        Сообщение.Текст = "Не указан Покупатель, на которого выписывается товарная накладная!";
        Сообщение.Поле = "Покупатель";
        Сообщение.УстановитьДанные(ЭтотОбъект);
        Сообщение.Сообщить();
            
        // Сообщим платформе, что мы сами обработали проверку заполнения реквизита «Покупатель»
        ПроверяемыеРеквизиты.Удалить(Покупатель);

        // Так как информация не консистентна, то продолжать работу дальше смысла нет
        Отказ = Истина;
            
    КонецЕсли;

    // Сообщим платформе, что мы сами обрабатываем проверку реквизита товар в табличной части «Товары»
    ПроверяемыеРеквизиты.Удалить(ПроверяемыеРеквизиты.Найти("Товары.Товар"));

    // Обходим строки и проверяем заполнение реквизита
    Для Индекс = 0 По Товары.Количество()-1 Цикл
        СтрокаТовар = Товары.Получить(Индекс);
        Если Не ЗначениеЗаполнено(СтрокаТовар.Товар) Тогда
            Сообщение = Новый СообщениеПользователю();
            Сообщение.Текст = "В строке " + Индекс + " не заполнено значение товара";
            Сообщение.Поле = "Товары[" + Индекс + "].Товар";
            Сообщение.УстановитьДанные(ЭтотОбъект);
            Сообщение.Сообщить();
            Отказ = Истина;
        КонецЕсли;
    КонецЦикла;
    
КонецПроцедуры

Поиск:
1С:Предприятие • Обработка проверки заполнения • Проверяемые реквизиты • Реквизит • Управляемая форма

Вывод сообщения о незаполненном поле документа

Я
   LivingStar

20.09.19 — 14:08

УТ 11, Документ.ЗаказКлиента.

При записи документа нужно выводить сообщение о том что не заполнено одно из полей на форме.

В зависимости от выбранного значения в списке другого поля. Подскажите пожалуйста. Где правильно это сделать?

В какой процедуре? В модуле формы или модуле объекта?

   GROOVY

1 — 20.09.19 — 14:11

В обработкеПроверкиЗаполнения

   LivingStar

2 — 20.09.19 — 14:13

В процедуре ОбработкаПроверкиЗаполненияВМодулеФормы ?

   Mankubus

3 — 20.09.19 — 14:14

объекта

   trooba

4 — 20.09.19 — 14:15

(2) Пример из типовой, тут есть обращение к обеим функциям, думаю разберетесь:

Если УчетТоваров.НеУказанаСтранаПроисхождения(СтрокаТовары.НомерГТД, СтрокаТовары.СтранаПроисхождения) Тогда

                ТекстСообщения = ОбщегоНазначенияКлиентСервер.ТекстОшибкиЗаполнения(«Колонка»,, НСтр(«ru = ‘Страна происхождения'»),

                    СтрокаТовары.НомерСтроки, ИмяСписка);

                    
                Поле = ОбщегоНазначенияКлиентСервер.ПутьКТабличнойЧасти(«Товары», СтрокаТовары.НомерСтроки, «СтранаПроисхождения»);

                ОбщегоНазначенияКлиентСервер.СообщитьПользователю(ТекстСообщения, ЭтотОбъект, Поле, «Объект», Отказ);

            КонецЕсли;

   LivingStar

5 — 20.09.19 — 14:33

(4) Обязательно так сложно делать?

Может перед записью? Если значение поля не такое то, и если не заполнено такое то поле, то сообщить то то?

(4) Это сходу не понять.

(3) В модуле документа? Я видел процедуру (2) в модуле формы. То есть нужно её сейчас искать именно в модуле объекта?

   LivingStar

6 — 20.09.19 — 14:34

(1) (3) Вижу процедуру ОбработкаПроверкиЗаполнения в модуле объекта.

То есть нужно делать именно в ней? А в какой момент она выполняется?

   palsergeich

7 — 20.09.19 — 14:39

(6) когда происходит проверка заполнения.

Она вызывается штатно платформой, так и может быть вызвана из кода.

Рекомендую почитать на ИТС или на ИС про это

   GROOVY

8 — 20.09.19 — 14:40

(6) Там в синтакс-помощник все ОЧЕНЬ подробно описано.

   LivingStar

9 — 20.09.19 — 14:59

Делаю в расширении в модуле объекта.

Почему выходит ошибка?

{ДМ_Документ_ЗаказКлиента Документ.ЗаказКлиента.МодульОбъекта(39,29)}: Переменная не определена (Объект)

        Если Не ЗначениеЗаполнено(<<?>>Объект.ДополнительнаяИнформацияПоДоставке1) Тогда (Проверка: Сервер)

//////////////////////////////////////////////////////////////

// LivingStar 2019_09_20 ->

&После(«ОбработкаПроверкиЗаполнения»)

Процедура ДМ_ОбработкаПроверкиЗаполнения(Отказ, ПроверяемыеРеквизиты)

    Если Не СпособДоставки = Перечисления.СпособыДоставки.Самовывоз Тогда

        Если Не ЗначениеЗаполнено(Объект.ДополнительнаяИнформацияПоДоставке1) Тогда

            
        КонецЕсли;

    КонецЕсли;

КонецПроцедуры

// <-

   LivingStar

10 — 20.09.19 — 15:49

Я сдела вот так, почему то по коду проходит, но сообщение не показывается (((((

&После(«ОбработкаПроверкиЗаполнения»)

Процедура ДМ_ОбработкаПроверкиЗаполнения(Отказ, ПроверяемыеРеквизиты)

    Если Не СпособДоставки = Перечисления.СпособыДоставки.Самовывоз Тогда

        Если Не ЗначениеЗаполнено(ЭтотОбъект.ДополнительнаяИнформацияПоДоставке) Тогда

            Сообщить(«Не заполнено поле <<Контактная и дополнительная информация по доставке !>>», СтатусСообщения.Информация);    

        КонецЕсли;

    КонецЕсли;

КонецПроцедуры

Почему?

   LivingStar

11 — 20.09.19 — 15:56

Сообщение не показывается. Что я не так делаю?

&После(«ОбработкаПроверкиЗаполнения»)

Процедура ДМ_ОбработкаПроверкиЗаполнения(Отказ, ПроверяемыеРеквизиты)

    Если Не СпособДоставки = Перечисления.СпособыДоставки.Самовывоз Тогда

        Если Не ЗначениеЗаполнено(ЭтотОбъект.ДополнительнаяИнформацияПоДоставке) Тогда

            Сообщить(«Не заполнено поле <<Контактная и дополнительная информация по доставке !>>», СтатусСообщения.Информация);    

            Текст = «Не заполнено поле <<Контактная и дополнительная информация по доставке !>>»;

            ОбщегоНазначенияКлиентСервер.СообщитьПользователю(Текст);

        КонецЕсли;

    КонецЕсли;

КонецПроцедуры

   LivingStar

12 — 20.09.19 — 16:03

Подскажите пожалуйста! Где мое сообщение????? Почему оно не показывается? Что я не так сделал??????

   Кодер

13 — 20.09.19 — 16:06

Последний вопрос, конечно, провоцирует…

Ты на УФ? Тогда зачем используешь «Сообщить»?

   palsergeich

14 — 20.09.19 — 16:08

Проверка заполнения сама плюется сообщениями, надо только поиграть с МассивПроверяемыхРеквмзитов

Я думал ты таки справку то почитал, там же усё написано(

   palsergeich

15 — 20.09.19 — 16:10

(14) ой проверяемыереквизиты, вот с ней надо поиграться

   Механик

16 — 20.09.19 — 16:21

(13) А разве «Сообщить» на УФ не работает?

   LivingStar

17 — 20.09.19 — 16:29

(13) Я как то хочу вывести сообщение. Как угодно. Что бы оно осталось. А то я нажимаю записать и закрыть, документ закрывается, велетает и пропадает какое то сообщение не мое а моего нет ((((( Мне хоть как бы , любым способом. Почему не срабытывает? Помогите!!!!!!

   LivingStar

18 — 20.09.19 — 16:30

Может эта процедура дурная????

ОбработкаПроверкиЗаполнения

И нужно делать в при записи и все будет работать?

Что не так у меня, подскажите?

   Кодер

19 — 20.09.19 — 16:31

Дамочка, прекратите истерику.

Не можете творить — не надо, копируйте чужой удачный код.

И это не работает — почитайте документацию.

Не поможет и это — мне надо керамогранит уложить в Зеленограде, бетономешалку дам, всему научу.

   craxx

20 — 20.09.19 — 16:32

(18) Андрюха, завязывай тупить

   LivingStar

21 — 20.09.19 — 16:35

Я с утра бывает могу хорошо работать, а после полудня ещё и под вечер, голова выключается. Вот дошел до того что не могу вывести сообщение ((( Что делать то?

   ам794123

22 — 20.09.19 — 16:35

(17) вам же в (4) сказали как делать

   SadrArt

23 — 20.09.19 — 16:36

(18) нет, это кто то другой дурной

   LivingStar

24 — 20.09.19 — 16:36

дело в параметрах да?

ТекстСообщения, ЭтотОбъект, Поле, «Объект», Отказ);

   SadrArt

25 — 20.09.19 — 16:38

у тебя сообщения выводятся, но ты их не видишь, потому как форма закрывается

сделай так, чтобы форма не закрывалась

   SadrArt

26 — 20.09.19 — 16:39

(13) + «ЭтотОбъект» в модуле объекта тоже кажется моветон

   Очевидно

27 — 20.09.19 — 16:39

   LivingStar

28 — 20.09.19 — 16:42

(25) Вечер, как не пытайся а мозгов в голове уже нет (((((( Теперь с утра нового дня уже.

   LivingStar

29 — 20.09.19 — 17:06

Как мне привязывать к форме сообщение то, если форма закрывается!

Как что бы оно осталось пользователю то, если документ закрылся?

   Очевидно

30 — 20.09.19 — 17:09

(29) в ссылке из (27) есть пример для копипаста

   LivingStar

31 — 20.09.19 — 17:21

Скажите я в правильном месте делаю вывод сообщения?

Форма то закрывается!!!

Как что бы сообщение осталось?

Не знаю что это даст

// LivingStar 2019_09_20 ->

&После(«ОбработкаПроверкиЗаполнения»)

Процедура ДМ_ОбработкаПроверкиЗаполнения(Отказ, ПроверяемыеРеквизиты)

    Если Не СпособДоставки = Перечисления.СпособыДоставки.Самовывоз Тогда

        Если Не ЗначениеЗаполнено(ЭтотОбъект.ДополнительнаяИнформацияПоДоставке) Тогда

            Сообщить(«Не заполнено поле <<Контактная и дополнительная информация по доставке !>>», СтатусСообщения.Информация);    

            Текст = «Не заполнено поле <<Контактная и дополнительная информация по доставке !>>»;

            ОбщегоНазначенияКлиентСервер.СообщитьПользователю(Текст, ЭтотОбъект, «ДополнительнаяИнформацияПоДоставке»,»Объект.ДополнительнаяИнформацияПоДоставке»);

        КонецЕсли;

    КонецЕсли;

КонецПроцедуры

// <-

Пробую. Мне нужно что бы сообщение осталось!

   LivingStar

32 — 20.09.19 — 17:22

(31) Какое то сообщение показывается, не моё, и все закрывается. Моего так и нет (

   LivingStar

33 — 20.09.19 — 18:02

может быть само положение сообщения куда то скрыто?

Так тоже не работает.

&НаСервере

Процедура ДМ_ПриЗаписиНаСервереПосле(Отказ, ТекущийОбъект, ПараметрыЗаписи)

    Если Не Объект.СпособДоставки = Перечисления.СпособыДоставки.Самовывоз Тогда

        Если Не ЗначениеЗаполнено(Объект.ДополнительнаяИнформацияПоДоставке) Тогда

            Сообщить(«Не заполнено поле <<Контактная и дополнительная информация по доставке !>>», СтатусСообщения.Информация);    

            //Текст = «Не заполнено поле <<Контактная и дополнительная информация по доставке !>>»;

            //ОбщегоНазначенияКлиентСервер.СообщитьПользователю(Текст, ЭтотОбъект, «ДополнительнаяИнформацияПоДоставке»,»Объект.ДополнительнаяИнформацияПоДоставке»);

        КонецЕсли;

    КонецЕсли;

КонецПроцедуры

   LivingStar

34 — 20.09.19 — 19:00

   LivingStar

35 — 20.09.19 — 19:07

Не работает

&НаКлиенте

Процедура ДМ_ПередЗаписьюПеред(Отказ, ПараметрыЗаписи)

    //ВсеОкна = ПолучитьОкна();

    //РабСтол = ВсеОкна[0];

    //РабСтол.Активизировать();

    //    

    ОкнаКлиентскогоПриложения = ПолучитьОкна();

    Для каждого ОкноКлиентскогоПриложения Из ОкнаКлиентскогоПриложения Цикл

        Если ОкноКлиентскогоПриложения.Основное Тогда

            ОкноКлиентскогоПриложения.Активизировать();

            Прервать;

        КонецЕсли;

    КонецЦикла;    

КонецПроцедуры

// <-

   LivingStar

36 — 20.09.19 — 19:22

Кто либо понимает о чем я говорю? Нажатие кнопки провести и закрыть закрывает документ и нет сообщения ( !!! Как что бы оно было после закрытия документа?

   Fram

37 — 20.09.19 — 21:33

(36) ты документацию принципиально не читаешь?

   LivingStar

38 — 21.09.19 — 06:13

(37)  Ну подскажите что читать? Какое решение? Везде пишут что это не возможно или какие то примеры которые не работают.

   PuhUfa

39 — 21.09.19 — 06:19

(38) не знай что ты где читаешь, но все возможно и все выше тебе уже подсказали. в той же ут11 примеров твоей «задачи» полно

   LivingStar

40 — 21.09.19 — 06:59

(39) Вы понимаете что мне нужно вывести сообщение по провести и закрыть?

Форма документа закрывается и нет никаких сообщений. Я пробовал все возможные варианты.

Подскажите хоть один я попробую.

   LivingStar

41 — 21.09.19 — 07:01

Не нужна мне процедура ОбработкаПроверкиЗаполнения.

То о чем я пишу принципиальная проблема, и по ней есть много статей, где это разбирается.

Одно из решений

2). Довольно часто необходимо вывести сообщение в обработке проведения документа, причем не только когда возникла ошибка при проведении, но и в том случае, когда документ успешно проведен. Проблема возникает когда пользователь использует команду “Провести и закрыть”. Сообщение привязывается к окну содержащему форму текущего документа, которое в случае успешного проведения тут же закрывается и пользователь его не видит. Все дело в том что метод Сообщить() объекта СообщениеПользователю выводит сообщение в АКТИВНОЕ окно, документ как правило открывается в дополнительном окне, которое в данном случае и является активным. Таким образом, что бы пользователь смог прочитать сообщение после закрытия формы документа, необходимо перед использованием метода Сообщить() активизировать основное окно управляемого приложения. Один из вариантов – сделать это в событии формы ПередЗаписью(), например так:

&НаКлиенте

Процедура ПередЗаписью(Отказ, ПараметрыЗаписи)

  ОкнаКлиентскогоПриложения = ПолучитьОкна();

  Для каждого ОкноКлиентскогоПриложения Из ОкнаКлиентскогоПриложения Цикл

    Если ОкноКлиентскогоПриложения.Основное Тогда

      ОкноКлиентскогоПриложения.Активизировать();

      Прервать;

     КонецЕсли;

  КонецЦикла;

КонецПроцедуры

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

Процедура ОбработкаПроведения(Отказ, РежимПроведения)

  // …..

  Сообщение = Новый СообщениеПользователю;

  Сообщение.Текст = «Проведен документ » + Ссылка;

  Сообщение.КлючДанных = Ссылка;

  Сообщение.Сообщить();

  // …..

КонецПроцедуры

Но у меня это не работает! Форма закрывается и моего сообщения нет

   LivingStar

42 — 21.09.19 — 09:17

up

   hhhh

43 — 21.09.19 — 09:44

(42) а точно окно основное? У тебя же не основное окно.

   rphosts

44 — 21.09.19 — 09:47

(0) о! ЛивингСтар! (42) см (1) там всё есть!

(41) а где вот это самое: Отказ = Истина;

   LivingStar

45 — 21.09.19 — 09:54

(44) Что такое отказ истина? Эточто бы документ оставался открытым при этом сообщении????

Этого не нужно.

Нужно что бы документ закрылся и вывелось сообщение. Как это сделать?

(43) Вы про какое окно? Вот http://joxi.ru/GrqW64zi4DaqP2

Я пытаюсь понять как это сделать и можно ли вообще.

Пользователь, нажимает «записать и закрыть», ему нужно вывести сообщение.

Вот такая задача, подскажите кто в теме, поправьте, или подскажите способ, что бы предметно и детально его испробовать, если есть рабочий.

   hhhh

46 — 21.09.19 — 10:02

(45) какое из всех этих окон Основное? Непонятно

   rphosts

47 — 21.09.19 — 10:02

это значит отказаться от продолжения процесса на этом этапе.

   Kashey

48 — 21.09.19 — 10:07

(45) Если проверяемое поле не заполнено, то документ должен проводиться или нет?

   hhhh

49 — 21.09.19 — 10:07

(47) ему не нужно отказываться, просто сообщить и двигаться дальше.

   LivingStar

50 — 21.09.19 — 10:09

(45) Основное — Это рабочий стол конфигурации. Основное окно конфигурации.

(48) Все должно выполняться как выполняется, без ограничений. Нужно только пользователю вывести окно и все.

   LivingStar

51 — 21.09.19 — 10:11

(47) Не нужно не от чего отказываться.

Пользователь жмет Записать и закрыть. Окно закрывается.

А пользователю выводится сообщение, —

    Если Не СпособДоставки = Перечисления.СпособыДоставки.Самовывоз Тогда

        Если Не ЗначениеЗаполнено(ЭтотОбъект.ДополнительнаяИнформацияПоДоставке) Тогда

            Сообщить(«Не заполнено поле <<Контактная и дополнительная информация по доставке !>>», СтатусСообщения.Информация);    

            Текст = «Не заполнено поле <<Контактная и дополнительная информация по доставке !>>»;

            ОбщегоНазначенияКлиентСервер.СообщитьПользователю(Текст, ЭтотОбъект, «ДополнительнаяИнформацияПоДоставке»,»Объект.ДополнительнаяИнформацияПоДоставке»);

        КонецЕсли;

    КонецЕсли;

Или как там его вывести. Любым способом, что бы оно осталось. В обычных формах с этим бы не было бы проблем.

   rphosts

52 — 21.09.19 — 10:11

(49) ну значит закроется вместе с сообщением оконце

   rphosts

53 — 21.09.19 — 10:13

(51) если у вас такие извращения… прячьте кнопки ЗаписатьИЗакрыть, Ок, Провести и втыкайте вместо них свои со своей логикой

   LivingStar

54 — 21.09.19 — 10:15

(53) Не нужно ничего прятать. Нужно сделать как заявлено.

Пользователь жмет, записать и закрыть.

Документ закрывается.

И если не заполнено это поле, то выводится сообщение об этом, и отображается.

А то сколько я его не вывожу его нет нигде.

   hhhh

55 — 21.09.19 — 10:17

(54) Ну, потому что рабочий стол это не основное окно. Ты где прочитал, что оно основное?

   rphosts

56 — 21.09.19 — 10:19

(54) оконце снизу — тексты всех вызовов Сообщить в нём. Если так нужно ещё и вернуться в закрытый уже документ — выкидывай туда этого документа Ссылку

   LivingStar

57 — 21.09.19 — 10:24

(55) Я же вот вам подчеркнул http://joxi.ru/GrqW64zi4DaqP2

Я не сам это придумал а взял решение, про которое говорят что оно работает (41)

Но оно не работает!!!!!!!

(56) Я не понимаю. Можете по коду подсказать?

Я перепробовал все что можно, ничего не работает!!!!!

   hhhh

58 — 21.09.19 — 10:31

(57) а какого года это решение в (41) ? Может оно столетнее? Точно на такси?

   hhhh

59 — 21.09.19 — 10:33

(57) А рабочий стол открывал после проведения? Может ты забыл открыть рабочий стол и там посмотреть?

   LivingStar

60 — 21.09.19 — 10:41

(59) После проведения и закрытия, когда документ закрывается

остается же рабочий стол????

Я СДЕЛАЛ ВОТ ТАК. ВСЕХ УСТРАИВАЕТ? ИЛИ ЧТО ТО НЕ ТАК? НЕ ВИЖУ ДРУГИХ ВАРИАНТОВ.

ЕСЛИ ВСЕ ЧТО И БЫЛО ТО СТОЛЕТНЕЕ. Я делаю в конфигурации УТ 11.4.7.141

/////////////////////////////////////////////////////

    // LivingStar 2019_09_21 ->

    Если Не Объект.СпособДоставки = ЗначениеСамовывоз() Тогда

        Если Не ЗначениеЗаполнено(Объект.ДополнительнаяИнформацияПоДоставке) Тогда

            Предупреждение(«Не заполнено поле»               + Символы.ПС +

                           «<<Контактная и дополнительная» + Символы.ПС +

                           «информация по доставке !>>»);    

        КонецЕсли;

    КонецЕсли;

    //

КонецПроцедуры                                                                                                                                          

//

Функция ЗначениеСамовывоз()

    Возврат Перечисления.СпособыДоставки.Самовывоз;

КонецФункции

// <-

   hhhh

61 — 21.09.19 — 10:43

(60) нет, рабочий стол не остаётся.

   LivingStar

62 — 21.09.19 — 10:44

(61) Ну не знаю тогда. Что сделать то что бы сообщение осталось???

Я уже не соображаю по этому поводу и решил остановиться на (60).

   hhhh

63 — 21.09.19 — 10:45

Поэтому вам не пойдёт это решение. Пользователю ещё кучу кнопок нажимать, чтобы перейти на рабочий стол и там потом внизу где-то смотреть, пришло ему сообщение или нет.

   LivingStar

64 — 22.09.19 — 08:41

(63) Какое решение тогда этой задачи?

Пользователь нажимает «Провести и закрыть», форма документа закрывается, нужно вывести сообщение пользователю.

   МимохожийОднако

65 — 22.09.19 — 08:44

(51) Правильнее и логичнее (ИМХО) при обязательных незаполненных полях делать отказ в записи документа, проведения и закрытии. Тогда не придётся городить огород с оповещением.

   Фрэнки

66 — 22.09.19 — 09:22

продолжу пост выше — при том, что в топике задано, что форма документа отрыта и Запись документа с проведением делается из его формы. И исходя из того, что нужен контроль на заполненные поля, либо реквизиты объекта в форме.

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

Если потребуется, то можно использовать и вызовы процедур в контексте Сервер. Но вся клиентская муть останется на клиенте и обработчиках событий клиента. И даже без оповещений можно обойтись.

з.ы. решение будет довольно простым и примитивным.

  

Fram

67 — 22.09.19 — 11:04

(64) правильнее будет задать вопрос какой смысл в этом сообщении после закрытия формы?

В 1С весь пользовательский интерфейс построен на формах. Для того чтобы наглядно в этом убедиться достаточно открыть любой документ или справочник. Формы создаются в режиме 1С:Конфигуратор. Для их создания необходимо обладать знаниями в области программирования 1С. Очень часто перед обработой данных с формы требуется выполнить проверку на заполненность обязательных полей. Это можно сделать несколькими способами.

Встроенные методы проверки заполнения

Во встроенном языке 1С есть функция для автоматической проверки заполнения полей формы. Функция ПроверитьЗаполнение() проверяет заполнение реквизитов у которых свойство «Проверка заполнения» установлено в значение «Показывать ошибку». Если реквизит не заполнен, то выводится сообщение об ошибке.

Свойство «Проверка заполнения» можно установить в двух местах:

1) В свойствах реквизита формы

Свойство проверка заполнения в реквизите формы


Свойство проверка заполнения в реквизите справочника

2) В свойствах реквизита объекта метаданных (справочника, документа и т.д)

Свойство проверка заполнения в реквизите справочника

Процедура ВыполнитьНажатие()Если НЕ ПроверитьЗаполнение() Тогда
Возврат;
КонецЕсли;//...
//...
//...

КонецПроцедуры

Программная проверка заполнения

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

Процедура ПроверитьЗаполнение()//Проверка ссылочных знаечний
Если Номенкалтура.Пустая() Тогда
Сообщить("Номенлатура пустая ссылка");
КонецЕсли;//Проверка строковых знаечний
Если ПустаяСтрока(Артикул) Тогда
Сообщить("Строка пустая");
КонецЕсли;//Проверка с помощью функции ЗначениеЗаполнено()
//Булево значение всегда заполнено
//Строка не пустая, если в строке есть непробельные символы
//Массив или коллекция не пустая, если в них есть хотя бы 1 элемент
//Неопределено и Null это всегда пустые значения
Если НЕ ЗначениеЗаполнено(Номенкалтура) Тогда
Сообщить("Номенлатура пустая ссылка");
КонецЕсли;Если НЕ ЗначениеЗаполнено(Артикул) Тогда
Сообщить("Строка пустая");
КонецЕсли;КонецПроцедуры

Как вызвать стандартную проверку заполнения реквизитов?

Код 1C v 8.2 УП

 ПроверитьЗаполнение()    

Возвращаемое значение:

Тип: Булево. Истина — ошибок не обнаружено, Ложь — в противном случае.

Описание:

Проверяет заполнение реквизитов. Для реквизитов, у которых свойство «Проверка заполнения» установлено в значение «Показывать ошибку» и реквизит не заполнен, будет сформировано сообщение об ошибке.

Доступность:

Тонкий клиент, веб-клиент, сервер, толстый клиент.

Код 1C v 8.2 УП

 &НаКлиенте
Процедура СформироватьБезСКД(Команда)
// Проверим заполнение обязательных реквизитов
Если Не ПроверитьЗаполнение() Тогда
Возврат;
КонецЕсли;
СформироватьСервер();
КонецПроцедуры

Обработчик проверки заполнения

У прикладных объектов на платформе 1С Предприятие 8.2 появился новый обработчик события ОбработкаПроверкиЗаполнения, где теперь рекомендуется делать все проверки на заполненность реквизитов объекта. Рассмотрим работу с этим обработчиком. Обработчик должен быть расположен в модуле объекта (для констант в модуле менеджера значений) и имеет следующий синтаксис:

Код 1C v 8.2 УП

 Процедура ОбработкаПроверкиЗаполнения(Отказ, ПроверяемыеРеквизиты) 
КонецПроцедуры

Здесь параметр Отказ (тип Булево) отвечает за возможность дальнейшей работы программы после проверки заполнения, а в параметре ПроверяемыеРеквизиты(тип Массив) содержатся реквизиты объекта, которые система будет проверять на заполненность. Напомним, что в версии 1С Предприятие 8.2 появилось возможность на уровне свойств реквизитов объекта устанавливать свойство Проверка заполнения. Так вот в массив ПроверяемыеРеквизиты по умолчанию система помещает реквизиты с установленным свойством «Выдавать ошибку». Однако разработчик может сам некоторые реквизиты добавить в массив или удалить из него в зависимости от каких-либо условий:

Код 1C v 8.2 УП

 Процедура ОбработкаПроверкиЗаполнения(Отказ, ПроверяемыеРеквизиты)

Клиент = ПроверяемыеРеквизиты.Найти("Контрагент");

Если Клиент<>Неопределено тогда

ПроверяемыеРеквизиты.Удалить(Клиент);

конецесли;

ПроверяемыеРеквизиты.Добавить("Склад");

КонецПроцедуры

Как видно из примера в качестве элементов массива выступают строковые наименование реквизитов, как они заданы в конфигураторе. Для того чтобы полностью отказаться от системной проверки, необходимо очистить массив. При этом разработчик может проводить проверку реквизитов по произвольным алгоритмам, система же проверяет только на заполненность/незаполненность:
Процедура ОбработкаПроверкиЗаполнения(Отказ, ПроверяемыеРеквизиты)

Код 1C v 8.2 УП

 ПроверяемыеРеквизиты.Очистить();

Если Контрагент.ПометкаУдаления Тогда

Отказ = Истина;

Сообщение = Новый СообщениеПользователю;

Сообщение.Текст = "Нельзя указывать контрагента, помеченного на удаление!";

Сообщение.Поле = "Контрагент";

Сообщение.УстановитьДанные(ЭтотОбъект);

Сообщение.Сообщить();

КонецЕсли;

КонецПроцедур

Далее рассмотрим, когда вызывается данный обработчик. Это зависит от типа объекта и его свойств. Так для, например, для справочника обработчик вызывается перед записью объекта; для документа: если разрешено проведение — при проведении, иначе при записи; для обработки : при вызове стандартных команд «OK», Да». Подробно это описано во встроенной справке. Но также есть возможность вызвать данный обработчик в произвольный момент, используя метод объекта ПроверитьЗаполнение(). Например, определить команду Проверить в форме документа:

Код 1C v 8.2 УП

 &НаКлиенте

Процедура Проверить(Команда)

ПроверитьНаСервере();

КонецПроцедуры

&НаСервере

Процедура ПроверитьНаСервере()

Документ = РеквизитФормыВЗначение("Объект");

Документ.ПроверитьЗаполнение();

КонецПроцедуры

Автор: Борис Захаров


Код 1C v 8.х

  //СписокРеквизитов - список значений. Элемент списка значений - имена реквизитов для проверки через запятую. 
//Если представление заполнено - считается, что передаются реквизиты табличной части. Пример:
СписокРеквизитовДляПроверки=Новый СписокЗначений;
СписокРеквизитовДляПроверки.Добавить("Контрагент,МестоХранения,ВидОперации");
СписокРеквизитовДляПроверки.Добавить("Номенклатура,Единица,Цена,Количество","ПолнаяТаблица");
СписокРеквизитовДляПроверки.Добавить("ВидОтклонений,Номенклатура,Единица,Серия,Цена,Количество","ТаблицаОтклонений");

Если Не глРеквизитыОбъектаЗаполнены(Источник,СписокРеквизитовДляПроверки) Тогда
Отказ=Истина;
Возврат;
КонецЕсли;

Функция глРеквизитыОбъектаЗаполнены(Объект,СписокРеквизитов) Экспорт
МетаданныеОбъекта=Объект.Метаданные();
МетаданныеТабличныеЧасти=МетаданныеОбъекта.ТабличныеЧасти;

РеквизитыЗаполнены=Истина;

СтрокаДляВыполнения="";

Для каждого НаборРеквизитов Из СписокРеквизитов Цикл
НаименованиеТаблицы=НаборРеквизитов.Представление;
РеквизитыДляПроверки=СтрЗаменить(НаборРеквизитов.Значение,",",Символы.ПС);

ДлинаСпискаРеквизитов=СтрЧислоСтрок(РеквизитыДляПроверки);

Если НаименованиеТаблицы<>"" Тогда
МетаданныеТаблица=МетаданныеТабличныеЧасти[НаименованиеТаблицы];
МетаданныеРевизитыТаблицы=МетаданныеТаблица.Реквизиты;

ТаблицаОбъекта=Объект[НаименованиеТаблицы];

Для СчетчикСтрокРевизитов=1 По ДлинаСпискаРеквизитов Цикл
ИдентРеквизита=СтрПолучитьСтроку(РеквизитыДляПроверки,СчетчикСтрокРевизитов);

МетаданныеРеквизит=МетаданныеРевизитыТаблицы[ИдентРеквизита];
ОписаниеТиповРеквизита=МетаданныеРеквизит.Тип;
ТипыЗначенийРеквизита=ОписаниеТиповРеквизита.Типы();

СтрокаПоиска=ТаблицаОбъекта.Найти(глПолучитьПустоеЗначениеТипа(ТипыЗначенийРеквизита[0]),ИдентРеквизита);
Если СтрокаПоиска=Неопределено Тогда
Продолжить;
КонецЕсли;

Возврат глВозвратЛожьССообщением("Не заполнен реквизит """+МетаданныеРеквизит.Синоним+""" Табличная часть строка "+СтрокаПоиска.НомерСтроки);
КонецЦикла;
Иначе
Для СчетчикСтрокРевизитов=1 По ДлинаСпискаРеквизитов Цикл
ИдентРеквизита=СтрПолучитьСтроку(РеквизитыДляПроверки,СчетчикСтрокРевизитов);

Если Не ЗначениеЗаполнено(Объект[ИдентРеквизита]) Тогда
МетаданныеРевизитыШапки=МетаданныеОбъекта.Реквизиты;
Попытка
Возврат глВозвратЛожьССообщением("Не заполнен реквизит """+МетаданныеРевизитыШапки[ИдентРеквизита].Синоним+"""");
Исключение
Возврат глВозвратЛожьССообщением("Не заполнен реквизит """+ИдентРеквизита+"""");
КонецПопытки;
КонецЕсли;
КонецЦикла;
КонецЕсли;
КонецЦикла;

Возврат Истина;
КонецФункции


Код 1C v 8.х

 // Ярослав Волохов aka YVolohov
// Функция проверяет заполнение шапки или табличной части справочника, документа или плана, бизнес-процесса, задачи
// Параметры:
// пИмяТаблицы (строка) - имя табличной части объекта, если не указано то будет проверятся шапка объекта
// пИменаПолей (массив строк) - имена проверяемых реквизитов объекта
// пВыводитьСообщения - если это свойство установлено в "Истина" то будут выводится сообщения в табло о
// незаполненных реквизитах таблицы, если не установлено - то не будут
// пСсылка (ссылка) - ссылка на элемент справочника или плана, документ, по которому будет произведена проверка
// Возвращаемое значение:
// Истина - если все реквизиты найдены и заполнены
// Ложь - если хоть один реквизит не заполнен, табличная часть не найдена
// или хоть один реквизит не найден

Функция ПроверитьЗаполнениеТаблицыОбъекта(пИмяТаблицы = Неопределено,
пИменаПолей, пВыводитьСообщения = Истина, пСсылка) Экспорт

МассивСообщений = Новый Массив;
ЗначениеВозврата = Истина;
МетаданныеОбъекта = пСсылка.Метаданные();

Если НЕ(пИмяТаблицы = Неопределено) Тогда
МетаданныеТаблицы = МетаданныеОбъекта.ТабличныеЧасти.Найти(пИмяТаблицы);
Иначе
МетаданныеТаблицы = МетаданныеОбъекта;
КонецЕсли;

// Проверка существования табличной части
Если НЕ(МетаданныеТаблицы = Неопределено) Тогда

МассивМетаданныхРеквизитов = Новый Массив;
МетаданныеРеквизитов = МетаданныеТаблицы.Реквизиты;

// Проверка существования полей
Для Каждого ИмяПоля Из пИменаПолей Цикл

МетаданныеРеквизита = МетаданныеРеквизитов.Найти(ИмяПоля);

Если НЕ(МетаданныеРеквизита = Неопределено) Тогда
МассивМетаданныхРеквизитов.Добавить(МетаданныеРеквизита);
Иначе

Если пИмяТаблицы = Неопределено Тогда
МассивСообщений.Добавить("Реквизит шапки с именем '" + ИмяПоля + "' не найден !!!");
Иначе
МассивСообщений.Добавить("Реквизит табличной части '" + пИмяТаблицы + "' с именем '" +
ИмяПоля + "' не найден !!!");
КонецЕсли;

ЗначениеВозврата = Ложь;
КонецЕсли;

КонецЦикла;

// Проверка заполнения полей
КоличествоСтрокТаблицы = ?(НЕ(пИмяТаблицы = Неопределено), пСсылка[пИмяТаблицы].Количество(), 1);
КоличествоСтрокТаблицы = ?(МассивМетаданныхРеквизитов.Количество() > 0, КоличествоСтрокТаблицы, 0);

// Обход строк таблицы
Для НомерСтрокиТаблицы = 1 По КоличествоСтрокТаблицы Цикл

СтрокаТаблицы = ?(НЕ(пИмяТаблицы = Неопределено),
пСсылка[пИмяТаблицы].Получить(НомерСтрокиТаблицы - 1), пСсылка);

// Обход списка проверяемых реквизитов
Для Каждого ЭлементМетаданныхРеквизитов Из МассивМетаданныхРеквизитов Цикл

// Получение значения ячейки и проверка ее заполнения
ЗначениеЯчейкиТЧ = СтрокаТаблицы[ЭлементМетаданныхРеквизитов.Имя];
ЯчейкаПустая = НЕ(ЗначениеЗаполнено(ЗначениеЯчейкиТЧ));

// Если значение пустое, добавляем сообщение в массив сообщений
Если ЯчейкаПустая Тогда

Если пИмяТаблицы = Неопределено Тогда
МассивСообщений.Добавить("Реквизит шапки с именем '" + ЭлементМетаданныхРеквизитов.Имя + "' не заполнен !!!");
Иначе
МассивСообщений.Добавить("В строке № " + НомерСтрокиТаблицы + " табличной части '" +
пИмяТаблицы + "' не заполнен реквизит с именем '" + ЭлементМетаданныхРеквизитов.Имя + "' !!!");
КонецЕсли;

ЗначениеВозврата = Ложь;

КонецЕсли;

КонецЦикла;

КонецЦикла;

Иначе
МассивСообщений.Добавить("Табличная часть с именем '" + пИмяТаблицы + "' не найдена !!!");
ЗначениеВозврата = Ложь;
КонецЕсли;

// Здесь выводим все сообщения
Если пВыводитьСообщения Тогда

Для Каждого ТекстСообщения Из МассивСообщений Цикл
Сообщить(ТекстСообщения, СтатусСообщения.Важное);
КонецЦикла;

КонецЕсли;

Возврат ЗначениеВозврата;

КонецФункции

Понравилась статья? Поделить с друзьями:
  • Ошибка если память не может быть рид
  • Ошибка если не является приложением win 32
  • Ошибка если не работает насос
  • Ошибка если не поставить дефис
  • Ошибка если не пересчитала ндфл