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

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

Запись от Maks размещена 10.04.2026 в 22:27. Обновил(-а) Maks 16.04.2026 в 07:10
Показов 2653 Комментарии 0

Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2.
Задача №1: при указании работ (справочник РаботыПоРемонтуСпецтехники), подставлять значение в реквизит "НормаВремени" в ТЧ "ВыполненныеРаботы".
1C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
// Норма времени для выбранного значения
&НаСервереБезКонтекста
Функция ПолучитьНормуВремени(Ссылка)   
    Если Ссылка.ПометкаУдаления Тогда
        Возврат Неопределено;
    КонецЕсли;     
    Возврат Ссылка.НормаВремени;   
КонецФункции
 
// Получаем норму времени в реквизите табличной части
&НаКлиенте
Процедура ВыполненныеРаботыНаименованиеРаботыПриИзменении(Элемент)   
    ТД = Элементы.ВыполненныеРаботы.ТекущиеДанные; 
    ТД.НормаВремени = ПолучитьНормуВремени(ТД.НаименованиеРаботы);    
КонецПроцедуры
Задача №2: при выборе сотрудника (справочник Сотрудники) в ТЧ документа подставлять значения, в виде должности, подразделения и графика работы, относящиеся к выбранному сотруднику, при этом "ГрафикРаботы" не является реквизитом справочника "Сотрудники". В качестве источника данных указан регистр сведений "РесурсыЛокаций", одним из регисторов данного регистра является нетиповой документ "ПоступлениеРесурсов" (сотрудники попадают в КА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
&НаСервере
Процедура СотрудникиСотрудникПриИзмененииНаСервере()   
    ТекДата = ТекущаяДатаСеанса();
    // Создаем массив сотрудников
    МассивСотрудников = Новый Массив;
    Для Каждого Строка Из Объект.Сотрудники Цикл
        Если ЗначениеЗаполнено(Строка.Сотрудник) Тогда
            МассивСотрудников.Добавить(Строка.Сотрудник);
        КонецЕсли;
    КонецЦикла;    
    Если МассивСотрудников.Количество() > 0 Тогда
        // Получаем необходимые данные из запроса
        Запрос = Новый Запрос;
        Запрос.Текст = 
            "ВЫБРАТЬ
            |   РесурсыЛокаций.Сотрудник КАК Сотрудник,
            |   РесурсыЛокаций.Должность КАК Должность,
            |   РесурсыЛокаций.Подразделение КАК Подразделение,
            |   РесурсыЛокаций.ГрафикРаботы КАК ГрафикРаботы
            |ИЗ
            |   РегистрСведений.РесурсыЛокаций.СрезПоследних(&ДатаСреза, ) КАК РесурсыЛокаций
            |ГДЕ
            |   РесурсыЛокаций.Сотрудник В(&Сотрудники)";       
        Запрос.УстановитьПараметр("ДатаСреза", ТекДата);
        Запрос.УстановитьПараметр("Сотрудники", МассивСотрудников); 
        Выборка = Запрос.Выполнить().Выбрать();
        ТаблицаДанных = Новый Соответствие;     
        Пока Выборка.Следующий() Цикл
            // Записываем данные в структуру
            ДанныеСтроки = Новый Структура("ГрафикРаботы, Должность, Подразделение", Выборка.ГрафикРаботы, Выборка.Должность, Выборка.Подразделение);
            ТаблицаДанных.Вставить(Выборка.Сотрудники, ДанныеСтроки);
        КонецЦикла;  
        // Подставляем значения в ТЧ документа
        Для Каждого ТекСтрока Из Объект.Сотрудники Цикл
            Если ЗначениеЗаполнено(ТекСтрока.Сотрудник) Тогда
                ТекДанные = ТаблицаДанных.Получить(ТекСтрока.Сотрудник);
                Если ТекДанные <> Неопределено Тогда
                    ТекСтрока.Должность = ТекДанные.Должность;
                    ТекСтрока.Подразделение = ТекДанные.Подразделение;
                    ТекСтрока.ГрафикРаботы = ТекДанные.ГрафикРаботы;
                КонецЕсли;            
            КонецЕсли;
        КонецЦикла;    
    КонецЕсли; 
КонецПроцедуры
 
// Вызываем процедуру на клиенте
&НаКлиенте
Процедура СотрудникиСотрудникПриИзменении(Элемент)   
    СотрудникиСотрудникПриИзмененииНаСервере();     
КонецПроцедуры
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Всего комментариев 0
Комментарии
 
Новые блоги и статьи
Поиск всех путей на ориентированном графе. Linux
dcc0 02.07.2026
Переработка старого кода из моей статьи. Через несколько переработок от PHP кода к C89 (надеюсь, 89). Но довольно запутанно получилось. Код для Linux. Но если убрать time и то, что с ним. . .
Сам себя обучал rest api
anaschu 02.07.2026
Педагогический лайфхак: Почему чистый REST API для ученика намного круче, чем готовые библиотеки Когда мы отказались от капризного JAR-файла AnyLogic и переписали код на стандартный HttpClient,. . .
rest api anylogic - выполнение модели на своём русском сайте
anaschu 02.07.2026
Как подружиться с AnyLogic Cloud API, победить провайдеров и развернуться Java-бэкенд в Docker на бесплатном хостинге: Двухдневный лог борьбы Всем привет! Хочу поделиться свежим (и довольно. . .
Где деньги лежат
kumehtar 02.07.2026
Это - японская подводная лодка I-52 (тип C2, кодовое имя Momi) вышла из Японии в марте 1944 года с миссией в оккупированную немцами Францию (Лорьян). Это была одна из «Янаги»-миссий по обмену. . .
Krabik для WoW 3.3.5a, многоязычный
AmbA 02.07.2026
Допилил бота, думаю что окончательно. Изменения: - добавлена многоязычность - добавлено снятие скриншотов - добавлено поддержание бафов хождения по воде (для жреца, дк и шамана) - и так, по. . .
Алиса нашла кучу ошибок компиляции и запуска в проекте, который без проблем компилировался и запускался)))
anaschu 30.06.2026
Я пока посмеюся, но завтра проверю. А вообще интерсно. Дал алисе файл, в котором точно нет ошибок компиляции и запуска, и попросил их найти. Нашла кучу))) Критические ошибки, мешающие компиляции и. . .
сукцессия 16. Общий обзор, в основном что бы другие ии поняли
anaschu 29.06.2026
# Передаточный документ: модель микоризной сукцессии (для нового чата) Этот документ предназначен для того, чтобы новый чат Claude мог продолжить работу без необходимости заново разбираться в. . .
сукцессия 15 неявная схема
anaschu 29.06.2026
Алиса Калибровка параметров симбиотической модели: технический обзор Содержание: Введение Постановка проблемы Технические аспекты реализации Процесс внедрения изменений
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru