Обработка заполнения самописная конфигурация
Добрый день, уважаемые читатели форума и эксперты.
Помогите разобраться в ситуации.
1. как показано в изображении имеем документ прихода с табличной частью.
2. имеем другой документ вк как показано в изображении без табличной части
3. То что куда должно вставлятся если создаем вк на основании приходного документа.
Так вот суть вопроса как при создании на основе сделать так чтобы документ ВК создался и заполнился столько раз сколько строк в документе приходная накладная. со всеми реквизитами.
Помогите разобраться в ситуации.
1. как показано в изображении имеем документ прихода с табличной частью.
2. имеем другой документ вк как показано в изображении без табличной части
3. То что куда должно вставлятся если создаем вк на основании приходного документа.
Так вот суть вопроса как при создании на основе сделать так чтобы документ ВК создался и заполнился столько раз сколько строк в документе приходная накладная. со всеми реквизитами.
Процедура ОбработкаЗаполнения(ДанныеЗаполнения, СтандартнаяОбработка)
//{{__КОНСТРУКТОР_ВВОД_НА_ОСНОВАНИИ
// Данный фрагмент построен конструктором.
// При повторном использовании конструктора, внесенные вручную изменения будут утеряны!!!
Если ТипЗнч(ДанныеЗаполнения) = Тип("ДокументСсылка.ПриходДокументов") Тогда
// Заполнение шапки
НомерФасонины = ДанныеЗаполнения.Комментарий;
Коментарий = ДанныеЗаполнения.Комментарий;
Обьект = ДанныеЗаполнения.ОбьектСтроительство;
Составил = ДанныеЗаполнения.Ответственный;
Дата = ДанныеЗаполнения.Дата;
//{{КОНСТРУКТОР_ЗАПРОСА_С_ОБРАБОТКОЙ_РЕЗУЛЬТАТА
// Данный фрагмент построен конструктором.
// При повторном использовании конструктора, внесенные вручную изменения будут утеряны!!!
КонецЕсли;
//}}__КОНСТРУКТОР_ВВОД_НА_ОСНОВАНИИ
КонецПроцедуры
ПоказатьПрикрепленные файлы:
По теме из базы знаний
- Обработка для заполнения документа КорректировкаРегистров (КорректировкаЗаписейРегистров) по данным регистров остатков
- Заполнение значениями по умолчанию для документов и справочников (универсальный механизм)
- Универсальная пакетная печать документов / справочников для типовых конфигураций 1С 8.2 - 8.3
- Универсальная система оповещений в базе или по почте по произвольным условиям, расписанием, ролям и пользователям (Расширение / конфигурация для платформ 8.3.6+, для ЛЮБЫХ баз)
- Создание обработки для выгрузки в Excel, PDF, Docx, TXT (управляемые формы)
Найденные решения
(16) ЗаполнитьЗначенияСвойств(Приемник,Источник) вам в помощь, если имена реквизитов одинаковые. Остальные реквизиты заполняются непосредственным указанием значений или реквизита.
НовыйДокумент.Договор = Объект.ДоговорКонтрагента;
НовыйДокумент.Сумма = стр.Сумма;;
НовыйДокумент.Договор = Объект.ДоговорКонтрагента;
НовыйДокумент.Сумма = стр.Сумма;;
Вот конечный результат
Вдруг кому пригодится
Вдруг кому пригодится
&НаСервере
Процедура Команда1НаСервере()
Для каждого стр из Объект.Таблица Цикл
Попытка
НовыйДокумент = Документы.Входной.СоздатьДокумент(); // Создает новый ВК
НовыйДокумент.Дата = Объект.Дата;
НовыйДокумент.Номенклатура = стр.Номенклатура;
НовыйДокумент.Количество = стр.Количество;
НовыйДокумент.Обьект = Объект.ОбьектСтроительство;
НовыйДокумент.Составил = Объект.Ответственный;
НовыйДокумент.СостояниеАкта = Перечисления.Состояние.Новый;
НовыйДокумент.Записать();
Сообщить("Документ по Входному контролю "+Объект.ВходящийДокумент+" успешно создан");
Исключение
Сообщить("Не удалось создать документ по Входному контролю"+Объект.ВходящийДокумент);
КонецПопытки;
КонецЦикла
КонецПроцедуры
&НаКлиенте
Процедура Команда1(Команда)
Команда1НаСервере();
КонецПроцедуры
ПоказатьОстальные ответы
Подписаться на ответы
Инфостарт бот
Сортировка:
Древо развёрнутое
Свернуть все
Открыл, конфигурации Бухгалтерия, и если честно потерялся.(((
в модуле обьекта платежное поручение обработка заполнения вот сюда же смотреть?
// Процедура - обработчик события "ОбработкаЗаполнения".
//
Процедура ОбработкаЗаполнения(Основание)
Если (Основание = Неопределено) ИЛИ Не ЭтотОбъект.Метаданные().Реквизиты.ДокументОснование.Тип.СодержитТип(ТипЗнч(Основание)) Тогда
Возврат;
КонецЕсли;
ВалютаДокумента = мВалютаРегламентированногоУчета;
ПараметрыДокументаОснования = ОбщегоНазначения.СформироватьСтруктуруШапкиДокумента(Основание);
ВидДокументаОснования = Основание.Метаданные().Имя;
ДокументОснование = ПараметрыДокументаОснования.Ссылка;
Если ВидДокументаОснования = "ПоступлениеТоваровУслуг"
или ВидДокументаОснования = "ПоступлениеДопРасходов"
или ВидДокументаОснования = "ПоступлениеНМА"
или ВидДокументаОснования = "ОтчетКомиссионераОПродажах"
или ВидДокументаОснования = "ОтчетКомитентуОПродажах"
или ВидДокументаОснования = "ВозвратТоваровОтПокупателя" тогда
/// Заполним реквизиты из стандартного набора по документу основанию.
ЗаполнениеДокументов.ЗаполнитьШапкуДокументаПоОснованию(ЭтотОбъект, Основание, Ложь);
Контрагент = ПараметрыДокументаОснования.Контрагент;
ИННПолучателя = Контрагент.ИНН;
ДоговорКонтрагента = ПараметрыДокументаОснования.ДоговорКонтрагента;
ВидРасчетовПоДоговору = БухгалтерскийУчетРасчетовСКонтрагентами.ОпределениеВидаРасчетовПоПараметрамДоговора(ДоговорКонтрагента,мВалютаРегламентированногоУчета);
Если ВидРасчетовПоДоговору=Перечисления.ВидыРасчетовПоДоговорам.РасчетыВИностраннойВалюте тогда
ВалютаДокумента = ПараметрыДокументаОснования.ВалютаВзаиморасчетов;
КонецЕсли;
СтруктураКурсаДокумента = МодульВалютногоУчета.ПолучитьКурсВалюты(ВалютаДокумента, Дата);
КурсДокумента = СтруктураКурсаДокумента.Курс;
КратностьДокумента = СтруктураКурсаДокумента.Кратность;
СтруктураКурсаВзаиморасчетов = МодульВалютногоУчета.ПолучитьКурсВалюты(ДоговорКонтрагента.ВалютаВзаиморасчетов, Дата);
ТаблицаПлатежей = Новый ТаблицаЗначений();
ТаблицаПлатежей.Колонки.Добавить("СуммаПлатежа", ОбщегоНазначения.ПолучитьОписаниеТиповЧисла(15,2));
ТаблицаПлатежей.Колонки.Добавить("СтавкаНДС", Новый ОписаниеТипов("ПеречислениеСсылка.СтавкиНДС"));
ТаблицаПлатежей.Колонки.Добавить("СуммаНДС", ОбщегоНазначения.ПолучитьОписаниеТиповЧисла(15,2));
Если ВидДокументаОснования = "ОтчетКомиссионераОПродажах"тогда
СуммаДокументаОснования = Новый ТаблицаЗначений();
СуммаДокументаОснования.Колонки.Добавить("СуммаПлатежа",ОбщегоНазначения.ПолучитьОписаниеТиповЧисла(15,2));
СуммаДокументаОснования.Колонки.Добавить("СтавкаНДС",Новый ОписаниеТипов("ПеречислениеСсылка.СтавкиНДС"));
СуммаДокументаОснования.Колонки.Добавить("СуммаНДС",ОбщегоНазначения.ПолучитьОписаниеТиповЧисла(15,2));
СтрокаТаблицыСумм = СуммаДокументаОснования.Добавить();
СтрокаТаблицыСумм.СтавкаНДС = ПараметрыДокументаОснования.СтавкаНДСВознаграждения;
СтрокаТаблицыСумм.СуммаНДС = Основание.Товары.Итог("СуммаНДСВознаграждения");
СтрокаТаблицыСумм.СуммаПлатежа = ?(ПараметрыДокументаОснования.СуммаВключаетНДС, ПараметрыДокументаОснования.СуммаВознаграждения, ПараметрыДокументаОснования.СуммаВознаграждения+СтрокаТаблицыСумм.СуммаНДС);
Иначе
СуммаДокументаОснования = УчетНДС.ПолучитьСуммуДокументаСНДСВРазрезеСтавокНДС(Основание);
СуммаДокументаОснования.Колонки.Сумма.Имя = "СуммаПлатежа";
Если ВидДокументаОснования = "ОтчетКомитентуОПродажах" Тогда
СуммаДокументаОснования.ЗаполнитьЗначения(0, "СуммаНДС");
Если ПараметрыДокументаОснования.УдержатьВознаграждение Тогда
СуммаКоррПлатежа= СуммаДокументаОснования.Итог("СуммаПлатежа") - ПараметрыДокументаОснования.СуммаВознаграждения;
НоваяКолонкаСумм = ОбщегоНазначения.РаспределитьПропорционально(СуммаКоррПлатежа,СуммаДокументаОснования.ВыгрузитьКолонку("СуммаПлатежа"));
Если не НоваяКолонкаСумм = Неопределено Тогда
СуммаДокументаОснования.ЗагрузитьКолонку(НоваяКолонкаСумм,"СуммаПлатежа");
КонецЕсли;
Если Не ПараметрыДокументаОснования.СуммаВключаетНДС Тогда
СуммаКоррНДС = СуммаДокументаОснования.Итог("СуммаПлатежа") - Основание.Товары.Итог("СуммаНДСВознаграждения");
НоваяКолонкаНДС = ОбщегоНазначения.РаспределитьПропорционально(СуммаКоррНДС,СуммаДокументаОснования.ВыгрузитьКолонку("СуммаПлатежа"));
Если не НоваяКолонкаНДС = Неопределено Тогда
СуммаДокументаОснования.ЗагрузитьКолонку(НоваяКолонкаНДС,"СуммаПлатежа");
КонецЕсли;
КонецЕсли;
КонецЕсли;
Если ПараметрыДокументаОснования.ДоговорКонтрагента.УчетАгентскогоНДС И Основание.Дата >= '20060101000000' Тогда
СуммаКоррНДС = СуммаДокументаОснования.Итог("СуммаПлатежа") - Основание.Товары.Итог("СуммаНДС");
НоваяКолонкаНДС = ОбщегоНазначения.РаспределитьПропорционально(СуммаКоррНДС,СуммаДокументаОснования.ВыгрузитьКолонку("СуммаПлатежа"));
Если не НоваяКолонкаНДС = Неопределено Тогда
СуммаДокументаОснования.ЗагрузитьКолонку(НоваяКолонкаНДС,"СуммаПлатежа");
КонецЕсли;
КонецЕсли;
ИначеЕсли ВидДокументаОснования = "ПоступлениеДопРасходов" тогда
Если Не(ПараметрыДокументаОснования.Сумма=0 и ПараметрыДокументаОснования.СуммаНДС=0) тогда
Если СуммаДокументаОснования.Количество()=0 тогда
СтрокаТаблицыСумм = СуммаДокументаОснования.Добавить();
Иначе
СтрокаТаблицыСумм = СуммаДокументаОснования[0];
КонецЕсли;
СтрокаТаблицыСумм.СуммаПлатежа = СтрокаТаблицыСумм.СуммаПлатежа + ПараметрыДокументаОснования.Сумма;
СтрокаТаблицыСумм.СуммаНДС = СтрокаТаблицыСумм.СуммаНДС + ПараметрыДокументаОснования.СуммаНДС;
Если не ПараметрыДокументаОснования.СуммаВключаетНДС Тогда
СтрокаТаблицыСумм.СуммаПлатежа = СтрокаТаблицыСумм.СуммаПлатежа+ПараметрыДокументаОснования.СуммаНДС;
КонецЕсли;
КонецЕсли;
СуммаДокументаОснования.ЗаполнитьЗначения(ПараметрыДокументаОснования.СтавкаНДС,"СтавкаНДС");
КонецЕсли;
КонецЕсли;
ОбщегоНазначения.ЗагрузитьВТаблицуЗначений(СуммаДокументаОснования, ТаблицаПлатежей);
Если ТаблицаПлатежей.Количество() = 0 тогда
ТаблицаПлатежей.Добавить();
КонецЕсли;
Для каждого СтрокаПлатеж Из ТаблицаПлатежей Цикл
Если ДоговорКонтрагента.УчетАгентскогоНДС Тогда
СтрокаПлатеж.СуммаПлатежа = СтрокаПлатеж.СуммаПлатежа - СтрокаПлатеж.СуммаНДС;
СтрокаПлатеж.СуммаНДС = 0;
СтрокаПлатеж.СтавкаНДС = Перечисления.СтавкиНДС.ПустаяСсылка();
КонецЕсли;
КонецЦикла;
ТаблицаПлатежей.Свернуть(, "СуммаПлатежа, СтавкаНДС, СуммаНДС");
СуммаДокумента = ТаблицаПлатежей.Итог("СуммаПлатежа");
СуммаНДС = ТаблицаПлатежей.Итог("СуммаПлатежа");
СтавкаНДС = ?(ТаблицаПлатежей.Количество() = 1, ТаблицаПлатежей[0].СтавкаНДС, "");
ИначеЕсли ТипЗнч(Основание) = Тип("ДокументСсылка.ЗарплатаКВыплатеОрганизаций") Тогда
Если Основание.СпособВыплаты = Перечисления.СпособыВыплатыЗарплаты.ЧерезКассу Тогда
Сообщить("Платежная ведомость оформлена на выплату через кассу.");
Возврат;
КонецЕсли;
/// Заполним реквизиты из стандартного набора по документу основанию.
ЗаполнениеДокументов.ЗаполнитьШапкуДокументаПоОснованию(ЭтотОбъект, Основание, Ложь);
ЗаполнитьДокументПоОснованиюРегл(Основание);
КонецЕсли;
Ответственный = глЗначениеПеременной("глТекущийПользователь");
КонецПроцедуры // ОбработкаЗаполнения()
Показать
в модуле обьекта платежное поручение обработка заполнения вот сюда же смотреть?
// Процедура - обработчик события "ОбработкаЗаполнения".
//
Процедура ОбработкаЗаполнения(Основание)
Если (Основание = Неопределено) ИЛИ Не ЭтотОбъект.Метаданные().Реквизиты.ДокументОснование.Тип.СодержитТип(ТипЗнч(Основание)) Тогда
Возврат;
КонецЕсли;
ВалютаДокумента = мВалютаРегламентированногоУчета;
ПараметрыДокументаОснования = ОбщегоНазначения.СформироватьСтруктуруШапкиДокумента(Основание);
ВидДокументаОснования = Основание.Метаданные().Имя;
ДокументОснование = ПараметрыДокументаОснования.Ссылка;
Если ВидДокументаОснования = "ПоступлениеТоваровУслуг"
или ВидДокументаОснования = "ПоступлениеДопРасходов"
или ВидДокументаОснования = "ПоступлениеНМА"
или ВидДокументаОснования = "ОтчетКомиссионераОПродажах"
или ВидДокументаОснования = "ОтчетКомитентуОПродажах"
или ВидДокументаОснования = "ВозвратТоваровОтПокупателя" тогда
/// Заполним реквизиты из стандартного набора по документу основанию.
ЗаполнениеДокументов.ЗаполнитьШапкуДокументаПоОснованию(ЭтотОбъект, Основание, Ложь);
Контрагент = ПараметрыДокументаОснования.Контрагент;
ИННПолучателя = Контрагент.ИНН;
ДоговорКонтрагента = ПараметрыДокументаОснования.ДоговорКонтрагента;
ВидРасчетовПоДоговору = БухгалтерскийУчетРасчетовСКонтрагентами.ОпределениеВидаРасчетовПоПараметрамДоговора(ДоговорКонтрагента,мВалютаРегламентированногоУчета);
Если ВидРасчетовПоДоговору=Перечисления.ВидыРасчетовПоДоговорам.РасчетыВИностраннойВалюте тогда
ВалютаДокумента = ПараметрыДокументаОснования.ВалютаВзаиморасчетов;
КонецЕсли;
СтруктураКурсаДокумента = МодульВалютногоУчета.ПолучитьКурсВалюты(ВалютаДокумента, Дата);
КурсДокумента = СтруктураКурсаДокумента.Курс;
КратностьДокумента = СтруктураКурсаДокумента.Кратность;
СтруктураКурсаВзаиморасчетов = МодульВалютногоУчета.ПолучитьКурсВалюты(ДоговорКонтрагента.ВалютаВзаиморасчетов, Дата);
ТаблицаПлатежей = Новый ТаблицаЗначений();
ТаблицаПлатежей.Колонки.Добавить("СуммаПлатежа", ОбщегоНазначения.ПолучитьОписаниеТиповЧисла(15,2));
ТаблицаПлатежей.Колонки.Добавить("СтавкаНДС", Новый ОписаниеТипов("ПеречислениеСсылка.СтавкиНДС"));
ТаблицаПлатежей.Колонки.Добавить("СуммаНДС", ОбщегоНазначения.ПолучитьОписаниеТиповЧисла(15,2));
Если ВидДокументаОснования = "ОтчетКомиссионераОПродажах"тогда
СуммаДокументаОснования = Новый ТаблицаЗначений();
СуммаДокументаОснования.Колонки.Добавить("СуммаПлатежа",ОбщегоНазначения.ПолучитьОписаниеТиповЧисла(15,2));
СуммаДокументаОснования.Колонки.Добавить("СтавкаНДС",Новый ОписаниеТипов("ПеречислениеСсылка.СтавкиНДС"));
СуммаДокументаОснования.Колонки.Добавить("СуммаНДС",ОбщегоНазначения.ПолучитьОписаниеТиповЧисла(15,2));
СтрокаТаблицыСумм = СуммаДокументаОснования.Добавить();
СтрокаТаблицыСумм.СтавкаНДС = ПараметрыДокументаОснования.СтавкаНДСВознаграждения;
СтрокаТаблицыСумм.СуммаНДС = Основание.Товары.Итог("СуммаНДСВознаграждения");
СтрокаТаблицыСумм.СуммаПлатежа = ?(ПараметрыДокументаОснования.СуммаВключаетНДС, ПараметрыДокументаОснования.СуммаВознаграждения, ПараметрыДокументаОснования.СуммаВознаграждения+СтрокаТаблицыСумм.СуммаНДС);
Иначе
СуммаДокументаОснования = УчетНДС.ПолучитьСуммуДокументаСНДСВРазрезеСтавокНДС(Основание);
СуммаДокументаОснования.Колонки.Сумма.Имя = "СуммаПлатежа";
Если ВидДокументаОснования = "ОтчетКомитентуОПродажах" Тогда
СуммаДокументаОснования.ЗаполнитьЗначения(0, "СуммаНДС");
Если ПараметрыДокументаОснования.УдержатьВознаграждение Тогда
СуммаКоррПлатежа= СуммаДокументаОснования.Итог("СуммаПлатежа") - ПараметрыДокументаОснования.СуммаВознаграждения;
НоваяКолонкаСумм = ОбщегоНазначения.РаспределитьПропорционально(СуммаКоррПлатежа,СуммаДокументаОснования.ВыгрузитьКолонку("СуммаПлатежа"));
Если не НоваяКолонкаСумм = Неопределено Тогда
СуммаДокументаОснования.ЗагрузитьКолонку(НоваяКолонкаСумм,"СуммаПлатежа");
КонецЕсли;
Если Не ПараметрыДокументаОснования.СуммаВключаетНДС Тогда
СуммаКоррНДС = СуммаДокументаОснования.Итог("СуммаПлатежа") - Основание.Товары.Итог("СуммаНДСВознаграждения");
НоваяКолонкаНДС = ОбщегоНазначения.РаспределитьПропорционально(СуммаКоррНДС,СуммаДокументаОснования.ВыгрузитьКолонку("СуммаПлатежа"));
Если не НоваяКолонкаНДС = Неопределено Тогда
СуммаДокументаОснования.ЗагрузитьКолонку(НоваяКолонкаНДС,"СуммаПлатежа");
КонецЕсли;
КонецЕсли;
КонецЕсли;
Если ПараметрыДокументаОснования.ДоговорКонтрагента.УчетАгентскогоНДС И Основание.Дата >= '20060101000000' Тогда
СуммаКоррНДС = СуммаДокументаОснования.Итог("СуммаПлатежа") - Основание.Товары.Итог("СуммаНДС");
НоваяКолонкаНДС = ОбщегоНазначения.РаспределитьПропорционально(СуммаКоррНДС,СуммаДокументаОснования.ВыгрузитьКолонку("СуммаПлатежа"));
Если не НоваяКолонкаНДС = Неопределено Тогда
СуммаДокументаОснования.ЗагрузитьКолонку(НоваяКолонкаНДС,"СуммаПлатежа");
КонецЕсли;
КонецЕсли;
ИначеЕсли ВидДокументаОснования = "ПоступлениеДопРасходов" тогда
Если Не(ПараметрыДокументаОснования.Сумма=0 и ПараметрыДокументаОснования.СуммаНДС=0) тогда
Если СуммаДокументаОснования.Количество()=0 тогда
СтрокаТаблицыСумм = СуммаДокументаОснования.Добавить();
Иначе
СтрокаТаблицыСумм = СуммаДокументаОснования[0];
КонецЕсли;
СтрокаТаблицыСумм.СуммаПлатежа = СтрокаТаблицыСумм.СуммаПлатежа + ПараметрыДокументаОснования.Сумма;
СтрокаТаблицыСумм.СуммаНДС = СтрокаТаблицыСумм.СуммаНДС + ПараметрыДокументаОснования.СуммаНДС;
Если не ПараметрыДокументаОснования.СуммаВключаетНДС Тогда
СтрокаТаблицыСумм.СуммаПлатежа = СтрокаТаблицыСумм.СуммаПлатежа+ПараметрыДокументаОснования.СуммаНДС;
КонецЕсли;
КонецЕсли;
СуммаДокументаОснования.ЗаполнитьЗначения(ПараметрыДокументаОснования.СтавкаНДС,"СтавкаНДС");
КонецЕсли;
КонецЕсли;
ОбщегоНазначения.ЗагрузитьВТаблицуЗначений(СуммаДокументаОснования, ТаблицаПлатежей);
Если ТаблицаПлатежей.Количество() = 0 тогда
ТаблицаПлатежей.Добавить();
КонецЕсли;
Для каждого СтрокаПлатеж Из ТаблицаПлатежей Цикл
Если ДоговорКонтрагента.УчетАгентскогоНДС Тогда
СтрокаПлатеж.СуммаПлатежа = СтрокаПлатеж.СуммаПлатежа - СтрокаПлатеж.СуммаНДС;
СтрокаПлатеж.СуммаНДС = 0;
СтрокаПлатеж.СтавкаНДС = Перечисления.СтавкиНДС.ПустаяСсылка();
КонецЕсли;
КонецЦикла;
ТаблицаПлатежей.Свернуть(, "СуммаПлатежа, СтавкаНДС, СуммаНДС");
СуммаДокумента = ТаблицаПлатежей.Итог("СуммаПлатежа");
СуммаНДС = ТаблицаПлатежей.Итог("СуммаПлатежа");
СтавкаНДС = ?(ТаблицаПлатежей.Количество() = 1, ТаблицаПлатежей[0].СтавкаНДС, "");
ИначеЕсли ТипЗнч(Основание) = Тип("ДокументСсылка.ЗарплатаКВыплатеОрганизаций") Тогда
Если Основание.СпособВыплаты = Перечисления.СпособыВыплатыЗарплаты.ЧерезКассу Тогда
Сообщить("Платежная ведомость оформлена на выплату через кассу.");
Возврат;
КонецЕсли;
/// Заполним реквизиты из стандартного набора по документу основанию.
ЗаполнениеДокументов.ЗаполнитьШапкуДокументаПоОснованию(ЭтотОбъект, Основание, Ложь);
ЗаполнитьДокументПоОснованиюРегл(Основание);
КонецЕсли;
Ответственный = глЗначениеПеременной("глТекущийПользователь");
КонецПроцедуры // ОбработкаЗаполнения()
В БСП тоже есть примеры обработки, которая подключается к внешним отчетам и обработкам и содержит модуль заполнение на основании.
Принцип такой:
1 Обработка подключается как дополнительная и выглядит как кнопка в журнале или в документе основании.
2. Пользователь нажимает на эту кнопку вместо стандартного ввода на основании.
3. По вашему выбору либо открывается окно для ввода дополнительной информации либо сразу создаются программно пакет нужных вам документов.
Принцип такой:
1 Обработка подключается как дополнительная и выглядит как кнопка в журнале или в документе основании.
2. Пользователь нажимает на эту кнопку вместо стандартного ввода на основании.
3. По вашему выбору либо открывается окно для ввода дополнительной информации либо сразу создаются программно пакет нужных вам документов.
(9) Что не получается?
Не нужна ни какая процедура заполнения (типовая).
Просто создаешь на форме кнопку (или как команду, если хочешь в списке видеть). И пишешь код, что то вроде этого:
Единственный недостаток, это все созданные документы будут записаны в базу сразу, но по другому ни как не создать не записывая множество документов в базе.
Не нужна ни какая процедура заполнения (типовая).
Просто создаешь на форме кнопку (или как команду, если хочешь в списке видеть). И пишешь код, что то вроде этого:
Для каждого стр из ТабличнойЧасти Цикл
Об = Документы.НужныйДокумент.Создать();
//Здесь заполняешь документ
Об.Записать();
ОткрытьФорму("ПутьКФормеДокумента",Новый Структура("Ключ",Об.Ссылка)); //Открываем документ
КонецЦикла;
Единственный недостаток, это все созданные документы будут записаны в базу сразу, но по другому ни как не создать не записывая множество документов в базе.
(10) Спасибо за пример.
вот что получилось.
При этом ошибку не выдал а создал 1800 документов которые не нужны мне***(((
вот что получилось.
&НаСервере
Процедура Команда1НаСервере()
Запрос = Новый Запрос;
Запрос.Текст = "ВЫБРАТЬ
| ПриходДокументов.ОбьектСтроительство КАК ОбьектСтроительство
|ИЗ
| Документ.ПриходДокументов КАК ПриходДокументов";
Результат = Запрос.Выполнить().Выгрузить();
Для Каждого ЭлементРезультата из Результат Цикл
Попытка
НовыйДокумент = Документы.Входной.СоздатьДокумент(); // Создает новый ВК
НовыйДокумент.Обьект = ЭлементРезультата.ОбьектСтроительство; //Заполняем данными
НовыйДокумент.Дата = ТекущаяДата();
НовыйДокумент.Записать();
Сообщить("Документ по договору "+ЭлементРезультата.ОбьектСтроительство+" успешно создан");
Исключение
Сообщить("НЕ УДАЛОСЬ создать окумент по договору "+ЭлементРезультата.ОбьектСтроительство);
КонецПопытки;
КонецЦикла;
КонецПроцедуры
&НаКлиенте
Процедура Команда1(Команда)
Команда1НаСервере();
КонецПроцедуры
ПоказатьПри этом ошибку не выдал а создал 1800 документов которые не нужны мне***(((
Правильно, потому что так написали, этот код бы создал и больше документов, но у Вас там их всего 1800.
В данном случае запрос не нужен, вы уже находитесь в документе.
Можно и запросом сделать, но:
1) В запрос добавьте условие, а то выборка получилась всех документов.
2) Запрос делайте сразу к табличной части, с выборкой всех данных, иначе смысла в запросе нет.
2) Проверяйте перед заполнением, что документ записан в базу, так как документ могут поменять, но еще не записать в базу. И заполнение произойдет по старым данным.
В данном случае запрос не нужен, вы уже находитесь в документе.
Можно и запросом сделать, но:
1) В запрос добавьте условие, а то выборка получилась всех документов.
2) Запрос делайте сразу к табличной части, с выборкой всех данных, иначе смысла в запросе нет.
2) Проверяйте перед заполнением, что документ записан в базу, так как документ могут поменять, но еще не записать в базу. И заполнение произойдет по старым данным.
(11) да и заполнились документы криво
Это что за заполнение данных?
И вам надо заполнять построчно, а заполняете по объекту, если вообще такое работает.
Если уж хотите заполнить однотипные реквизиты, то делается это так:
НовыйДокумент.Обьект = ЭлементРезультата.ОбьектСтроительство; //Заполняем данными
Это что за заполнение данных?
И вам надо заполнять построчно, а заполняете по объекту, если вообще такое работает.
Если уж хотите заполнить однотипные реквизиты, то делается это так:
ЗаполнитьЗначенияСвойств(НовыйДокумент,ЭлементРезультата.ОбьектСтроительство);
Все создает столько документов сколько строк в документе.
Наверное это уже будет наглость. но не могли бы подсказать с заполнением еще
Наверное это уже будет наглость. но не могли бы подсказать с заполнением еще
Для каждого стр из Объект.Таблица Цикл
Попытка
НовыйДокумент = Документы.Входной.СоздатьДокумент(); // Создает новый ВК
НовыйДокумент.Дата = Элементы.Дата();
//НовыйДокумент.Составил = Элементы.Ответственный;
НовыйДокумент.Записать();
Сообщить("Документ по входному контролю "+Объект.ВходящийДокумент+" успешно создан");
Исключение
Сообщить("НЕ УДАЛОСЬ создать документ по Входному "+Объект.ВходящийДокумент);
КонецПопытки;
КонецЦикла
Показать
(16) ЗаполнитьЗначенияСвойств(Приемник,Источник) вам в помощь, если имена реквизитов одинаковые. Остальные реквизиты заполняются непосредственным указанием значений или реквизита.
НовыйДокумент.Договор = Объект.ДоговорКонтрагента;
НовыйДокумент.Сумма = стр.Сумма;;
НовыйДокумент.Договор = Объект.ДоговорКонтрагента;
НовыйДокумент.Сумма = стр.Сумма;;
Вот конечный результат
Вдруг кому пригодится
Вдруг кому пригодится
&НаСервере
Процедура Команда1НаСервере()
Для каждого стр из Объект.Таблица Цикл
Попытка
НовыйДокумент = Документы.Входной.СоздатьДокумент(); // Создает новый ВК
НовыйДокумент.Дата = Объект.Дата;
НовыйДокумент.Номенклатура = стр.Номенклатура;
НовыйДокумент.Количество = стр.Количество;
НовыйДокумент.Обьект = Объект.ОбьектСтроительство;
НовыйДокумент.Составил = Объект.Ответственный;
НовыйДокумент.СостояниеАкта = Перечисления.Состояние.Новый;
НовыйДокумент.Записать();
Сообщить("Документ по Входному контролю "+Объект.ВходящийДокумент+" успешно создан");
Исключение
Сообщить("Не удалось создать документ по Входному контролю"+Объект.ВходящийДокумент);
КонецПопытки;
КонецЦикла
КонецПроцедуры
&НаКлиенте
Процедура Команда1(Команда)
Команда1НаСервере();
КонецПроцедуры
Показать
Для получения уведомлений об ответах подключите телеграм бот:
Инфостарт бот