Форум программистов, компьютерный форум, киберфорум
Maks
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  

Валидация и контроль данных табличной части документа перед записью

Запись от Maks размещена 22.04.2026 в 12:25
Показов 1949 Комментарии 0

Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2.
Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании Заказчика и прав доступа.

1C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
// Установка глобальной переменной на клиенте
&НаКлиенте
перем мРассчитано
 
// Установка значения для глобальной переменной "мРассчитано"
&НаКлиенте
Процедура СброситьРасчет()
    мРассчитано = Ложь;
    Модифицированность = Истина;
КонецПроцедуры
 
// Изменение таблицы работ с показателями делает расчёт недействительным
&НаКлиенте
Процедура ТаблицаРаботСПоказателямиВыбор(Элемент, ВыбраннаяСтрока, Поле, СтандартнаяОбработка)
    СброситьРасчет();
КонецПроцедуры
 
&НаКлиенте
Процедура ТаблицаРаботСПоказателямиПриНачалеРедактирования(Элемент, НоваяСтрока, Копирование)
    СброситьРасчет();
КонецПроцедуры
 
&НаКлиенте
Процедура ТаблицаРаботСПоказателямиПриИзменении(Элемент)
    СброситьРасчет(); 
КонецПроцедуры
 
// Установка флага для соответствующей роли
&НаСервере
Процедура ИсключитьРоль()
    мПрава = РольДоступна("ПолныеПрава");
КонецПроцедуры
 
&НаКлиенте
Процедура ПередЗаписью(Отказ, ПараметрыЗаписи)
    // Общие данные и контроль расчета документа
    ТекДата = ТекущаяДата(); 
    ДатаДокумента = Объект.Дата;
    ОчиститьСообщения();
    // Проверка наличия прав
    Если мПрава = Ложь Тогда
        Если ТаблицаРаботСПоказателями.Количество() > 0 
           И НЕ мРассчитано 
           И ДатаДокумента >= НачалоМесяца(ТекДата) Тогда
            // Фокус на ТЧ + сообщение о нерассчитанных работах
            ЭтаФорма.ТекущийЭлемент = ЭтаФорма.Элементы.ТаблицаРаботСПоказателями;
            Сообщить("Состав работ не рассчитан!");             
        КонецЕсли;  
    КонецЕсли;
    // Цикл валидации строк табличной части
    Для Каждого Строка Из ТаблицаРаботСПоказателями Цикл
        // Инициализация переменных ошибки
        ТекстОшибки = "";
        ИмяПоля = "";
        // Проверка корректности интервалов
        Если ЗначениеЗаполнено(Строка.ИнтервалОт) 
           И ЗначениеЗаполнено(Строка.ИнтервалДо) 
           И Строка.ИнтервалОт > Строка.ИнтервалДо Тогда       
            ТекстОшибки = "Начало интервала не может быть больше его окончания!";
            ИмяПоля = "ИнтервалОт";        
        // Проверка заполнения окончания интервала
        ИначеЕсли Строка.ИнтервалДо = 0 
            И Строка.ИнтервалОт > 0 Тогда      
            ТекстОшибки = "Не указано окончание интервала!";
            ИмяПоля = "ИнтервалДо";   
        // Контроль обязательных полей по типу строки (ВМ)
        ИначеЕсли Строка.ТипСтроки = ПредопределенноеЗначение("Перечисление.ТипыРабот.ВМ") 
            И (НЕ ЗначениеЗаполнено(Строка.КоличествоСПО) ИЛИ Строка.КоличествоСПО = 0) Тогда      
            ТекстОшибки = "Не указано количество СПО для ВМ!";
            ИмяПоля = "КоличествоСПО";
        КонецЕсли;
        // Формирование и вывод ошибки пользователю
        Если ТекстОшибки <> "" Тогда        
            Сообщение = Новый СообщениеПользователю;
            Сообщение.Текст = ТекстОшибки;
            Сообщение.Поле = СтрШаблон(
                "ТаблицаРаботСПоказателями[%1]." + ИмяПоля,
                ТаблицаРаботСПоказателями.Индекс(Строка)
            );
            Сообщение.Сообщить();
            Отказ = Истина;
        КонецЕсли;
    КонецЦикла;
КонецПроцедуры
Размещено в
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Всего комментариев 0
Комментарии
 
Новые блоги и статьи
Контроль уникальности выбранного документа-основания при изменении реквизита
Maks 28.04.2026
Алгоритм из решения ниже разработан на примере нетипового документа "ЗаявкаНаРемонтСпецтехники", разработанного в КА2. Задача: уведомлять пользователя, если указанная заявка (документ-основание). . .
Благородство как наказание
Maks 24.04.2026
У хорошего человека отношения с женщинами всегда складываются трудно. А я человек хороший. Заявляю без тени смущения, потому что гордиться тут нечем. От хорошего человека ждут соответствующего. . .
Валидация и контроль данных табличной части документа перед записью
Maks 22.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в КА2. Задача: контроль и валидация данных табличной части документа перед записью с учетом регламента компании. . .
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru