Автоматизация процесса формирования документов реализации в лизинговой компании

20.11.19

Учетные задачи - Оптовая торговля

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

Файлы

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование Скачано Купить файл
Формирование РТиУ
.epf 7,74Kb
1 2 500 руб. Купить
Сравнение фактически поступивших платежей с графиком платежей
.erf 8,25Kb
0 2 500 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

Постановка задачи:

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

Решение:

Необходимо где-то хранить информацию о графике платежа (дата платежа и сумма платежа). В конфигурацию "Бухгалтерия предприятия, редакция 3.0" был добавлен новый справочник "ГрафикПлатежей" (можно добавить в расширение). 

Реквизиты: Контрагент, Договор, ВидДоговора

Табличная часть: Платежи (ДатаПлатежа, СуммаПлатежа)

 

В форму элемента справочника выведены реквизиты: Наименование, Контрагент, Договор, Вид договора и Табличная часть "Оплата" с реквизитами ДатаПлатежа и СуммаПлатежа.

 

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

&НаСервере
Функция СформироватьРТиУНаСервере()
	РТУ = Документы.РеализацияТоваровУслуг.СоздатьДокумент();
	Сегодня = ТекущаяДата();
	РТУ.Дата = КонецМесяца(Сегодня);
	РТУ.Организация = Справочники.Организации.НайтиПоНаименованию("ООО ""Наша фирма""");
	РТУ.ВидОперации = Перечисления.ВидыОперацийРеализацияТоваров.Услуги;
	РТУ.ДоговорКонтрагента = Объект.Договор;
	РТУ.ВалютаДокумента = Объект.Договор.ВалютаВзаиморасчетов;
	РТУ.Контрагент = Объект.Договор.Владелец;
	РТУ.СчетУчетаРасчетовСКонтрагентом = ПланыСчетов.Хозрасчетный.НайтиПоКоду("62.01");
	РТУ.СчетУчетаРасчетовПоАвансам = ПланыСчетов.Хозрасчетный.НайтиПоКоду("62.02");
	РТУ.СпособЗачетаАвансов = Перечисления.СпособыЗачетаАвансов.Автоматически;
	РТУ.СуммаВключаетНДС = Истина;
	РТУ.ТипЦен = Справочники.ТипыЦенНоменклатуры.НайтиПоНаименованию("Основная цена продажи");
	ТекущийМесяц = Месяц(ТекущаяДата());
	ТекущийГод = Год(ТекущаяДата());
	НоваяСтрока = РТУ.Услуги.Добавить();
	Если Объект.ВидДоговора.Наименование = "Аренда" Тогда
		НоваяСтрока.Номенклатура = Справочники.Номенклатура.НайтиПоКоду("00000000333");
		НоваяСтрока.Субконто = Справочники.НоменклатурныеГруппы.НайтиПоНаименованию("Аренда");
	ИначеЕсли
		Объект.ВидДоговора.Наименование = "Лизинговый платеж"
		Тогда
		НоваяСтрока.Номенклатура = Справочники.Номенклатура.НайтиПоКоду("00000000025");
		НоваяСтрока.Субконто = Справочники.НоменклатурныеГруппы.НайтиПоНаименованию("Лизинговый платеж");
	КонецЕсли;
	НоваяСтрока.Содержание = Строка(НоваяСтрока.Номенклатура)+" по договору "+Строка(Объект.Договор);
	НоваяСтрока.СтавкаНДС = Перечисления.СтавкиНДС.НДС20;
	НоваяСтрока.СчетДоходов = ПланыСчетов.Хозрасчетный.НайтиПоКоду("90.01.1");
	НоваяСтрока.СчетРасходов = ПланыСчетов.Хозрасчетный.НайтиПоКоду("90.02.1");
	НоваяСтрока.СчетУчетаНДСПоРеализации = ПланыСчетов.Хозрасчетный.НайтиПоКоду("90.03");
	
	Для Каждого Элемент из Объект.Платежи Цикл
		Если ТекущийМесяц = Месяц(Элемент.ДатаПлатежа) И ТекущийГод = Год(Элемент.ДатаПлатежа) Тогда
			НоваяСтрока.Цена = Элемент.СуммаПлатежа;
			НоваяСтрока.Сумма = Элемент.СуммаПлатежа;
			НоваяСтрока.СуммаНДС = Элемент.СуммаПлатежа*(1-1/1.2);
		КонецЕсли;
	КонецЦикла;
	
	РТУ.Записать(РежимЗаписиДокумента.Запись);
	Возврат РТУ.Ссылка;
КонецФункции

&НаКлиенте
Процедура СформироватьРТиУ(Команда)
	ОткрытьЗначение(СформироватьРТиУНаСервере());
КонецПроцедуры

Таким образом, при нажатии на кнопку "Сформировать РТиУ" формируется документ реализации, заполняется шапка документа, табличная часть "Услуги" и документ записывается с датой последнего дня текущего месяца. 

Табличная часть заполняется в соответствии со значениями справочника "График платежей"

Так можно сформировать документ для каждого конкретного договора.

 

Для того, чтобы сформировать документы по нескольким договорам была написана внешняя обработка "Формирование РТиУ"

 

В модуле формы обработки при нажатии на кнопку "Заполнить" сначала заполняем таблицу из справочника "График платежей"

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

&НаКлиенте
Процедура Заполнить(Команда)
	ЗаполнитьНаСервере();
КонецПроцедуры

 

Затем, при нажатии на кнопку "Сформировать РТиУ" формируем документы, которые отмечены крыжиком

&НаСервере
Процедура СформироватьРТУНаСервере()
	
	Для каждого Строка Из Таблица Цикл
		Если Строка.Выбор Тогда
			Выборка = Строка.График;		
			РТУ = Документы.РеализацияТоваровУслуг.СоздатьДокумент();
			Сегодня = ТекущаяДата();
			//РТУ.Дата = Дата(Год(Сегодня),Месяц(Сегодня),20);
			РТУ.Дата = КонецМесяца(Сегодня);
			РТУ.Организация = Справочники.Организации.НайтиПоНаименованию("ООО ""Наша фирма""");
			РТУ.ВидОперации = Перечисления.ВидыОперацийРеализацияТоваров.Услуги;
			РТУ.ДоговорКонтрагента = Выборка.Договор;
			РТУ.ВалютаДокумента = Выборка.Договор.ВалютаВзаиморасчетов;
			РТУ.Контрагент = Выборка.Договор.Владелец;
			РТУ.СчетУчетаРасчетовСКонтрагентом = ПланыСчетов.Хозрасчетный.НайтиПоКоду("62.01");
			РТУ.СчетУчетаРасчетовПоАвансам = ПланыСчетов.Хозрасчетный.НайтиПоКоду("62.02");
			РТУ.СпособЗачетаАвансов = Перечисления.СпособыЗачетаАвансов.Автоматически;
			РТУ.СуммаВключаетНДС = Истина;
			РТУ.ТипЦен = Справочники.ТипыЦенНоменклатуры.НайтиПоНаименованию("Основная цена продажи");
			ТекущийМесяц = Месяц(ТекущаяДата());
			ТекущийГод = Год(ТекущаяДата());
			НоваяСтрока = РТУ.Услуги.Добавить();
			Если Выборка.ВидДоговора.Наименование = "Аренда" Тогда
				НоваяСтрока.Номенклатура = Справочники.Номенклатура.НайтиПоКоду("00000000333");
				НоваяСтрока.Субконто = Справочники.НоменклатурныеГруппы.НайтиПоНаименованию("Аренда");
			ИначеЕсли
				Выборка.ВидДоговора.Наименование = "Лизинговый платеж"
				Тогда
				НоваяСтрока.Номенклатура = Справочники.Номенклатура.НайтиПоКоду("00000000025");
				НоваяСтрока.Субконто = Справочники.НоменклатурныеГруппы.НайтиПоНаименованию("Лизинговый платеж");
			КонецЕсли;
			НоваяСтрока.Содержание = Строка(НоваяСтрока.Номенклатура)+" по договору "+Строка(Выборка.Договор);
			НоваяСтрока.СтавкаНДС = Перечисления.СтавкиНДС.НДС20;
			НоваяСтрока.СчетДоходов = ПланыСчетов.Хозрасчетный.НайтиПоКоду("90.01.1");
			НоваяСтрока.СчетРасходов = ПланыСчетов.Хозрасчетный.НайтиПоКоду("90.02.1");
			НоваяСтрока.СчетУчетаНДСПоРеализации = ПланыСчетов.Хозрасчетный.НайтиПоКоду("90.03");
			
			Для Каждого Элемент из Выборка.Платежи Цикл
				Если ТекущийМесяц = Месяц(Элемент.ДатаПлатежа) И ТекущийГод = Год(Элемент.ДатаПлатежа) Тогда
					НоваяСтрока.Цена = Элемент.СуммаПлатежа;
					НоваяСтрока.Сумма = Элемент.СуммаПлатежа;
					НоваяСтрока.СуммаНДС = Элемент.СуммаПлатежа*(1-1/1.2);
				КонецЕсли;
				
				
			КонецЦикла;
		
		РТУ.Записать(РежимЗаписиДокумента.Запись);	
		КонецЕсли;
	КонецЦикла;
КонецПроцедуры

&НаКлиенте
Процедура СформироватьРТУ(Команда)
	СформироватьРТУНаСервере();
КонецПроцедуры

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

 

Обработка в режиме предприятия

 

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

Запрос

ВЫБРАТЬ
	ГрафикПлатежейПлатежи.Ссылка.Наименование КАК Наименование,
	ГрафикПлатежейПлатежи.Ссылка.Контрагент КАК Контрагент,
	ГрафикПлатежейПлатежи.Ссылка.Договор КАК Договор,
	ГрафикПлатежейПлатежи.НомерСтроки КАК НомерСтроки,
	ГрафикПлатежейПлатежи.ДатаПлатежа КАК ДатаПлатежа,
	ГрафикПлатежейПлатежи.СуммаПлатежа КАК СуммаПлатежа,
	ПоступлениеНаРасчетныйСчет.Контрагент КАК Контрагент1,
	ПоступлениеНаРасчетныйСчет.Дата КАК Дата,
	ПоступлениеНаРасчетныйСчет.ДоговорКонтрагента КАК ДоговорКонтрагента,
	ПоступлениеНаРасчетныйСчет.СуммаДокумента КАК СуммаДокумента,
	ПоступлениеНаРасчетныйСчет.Ссылка КАК Ссылка
ИЗ
	Справочник.ГрафикПлатежей.Платежи КАК ГрафикПлатежейПлатежи
		ЛЕВОЕ СОЕДИНЕНИЕ Документ.ПоступлениеНаРасчетныйСчет КАК ПоступлениеНаРасчетныйСчет
		ПО ГрафикПлатежейПлатежи.Ссылка.Договор = ПоступлениеНаРасчетныйСчет.ДоговорКонтрагента
			И (НАЧАЛОПЕРИОДА(ГрафикПлатежейПлатежи.ДатаПлатежа, МЕСЯЦ) = НАЧАЛОПЕРИОДА(ПоступлениеНаРасчетныйСчет.Дата, МЕСЯЦ))

 

Сам отчет

 

В табличную часть справочника "График платежей" информация загружалась с использованием стандартной обработки "ЗагрузкаДанныхИзТабличногоДокумента.epf"

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

См. также

Оптовая торговля Розничная торговля Обмен с ГосИС Программист Бухгалтер Пользователь 1С:Предприятие 8 1C:Бухгалтерия Розничная и сетевая торговля (FMCG) Оптовая торговля, дистрибуция, логистика Россия Бухгалтерский учет Управленческий учет Платные (руб)

Решение создано для помощи разработчикам, интеграторам и другим заинтересованным лицам по настройке системы маркировки обуви, одежды, лекарств, табака, фото, молока, духов(парфюма), питьевой воды, велосипедов и шин. Задавайте вопросы по работе с ЦРПТ, GS1, ЭДО, Национальным каталогом, накоплен опыт и знания по данным темам.

5000 руб.

18.03.2019    121144    79    115    

200

Оптовая торговля Розничная торговля НДС 22% 1С 8.3 1С:Управление торговлей 10 Россия Платные (руб)

Пакет обновлений и продолжения поддержки Управление торговлей, редакция 10.3.- обновление которое предоставляет пользователям новые функции, исправления ошибок и т.д.

14640 руб.

19.12.2025    5932    61    33    

60

Оптовая торговля Розничная торговля Обмен с ГосИС Бухгалтер 1С:Предприятие 8 1С:Управление торговлей 10 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 Розничная и сетевая торговля (FMCG) Оптовая торговля, дистрибуция, логистика Рестораны, кафе и фаст-фуд Россия Бухгалтерский учет Управленческий учет Акцизы Платные (руб)

Автоматизация учета ЕГАИС в 1С для оптовой торговли, производства и импорта алкогольной продукции. Получение и отправка ТТН, отправка акта о постановке на баланс и акта о списании. Получение остатков. Загрузка и сопоставление номенклатуры и контрагентов. Оправка в ЕГАИС отчетов о производстве и импорте.

15.12.2015    181908    1227    biz-intel    374    

416

SALE! 15%

Загрузка и выгрузка в Excel Оптовая торговля Бухгалтер Пользователь 1С:Предприятие 8 1С:Бухгалтерия 2.0 1С:Бухгалтерия 3.0 1С:Управление производственным предприятием 1С:ERP Управление предприятием 2 1С:Управление холдингом 1С:Комплексная автоматизация 1.х 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 1.6 1С:Управление нашей фирмой 3.0 1С:Управление торговлей 10 1С:Управление торговлей 11 1С:Розница 2 1С:Розница 3.0 Бухгалтерский учет Управленческий учет Платные (руб)

Универсальная обработка для загрузки документов из Excel в 1С. Забудьте о ручном вводе: загружайте документы из Excel в 1С за секунды! Не требует указания параметров (номера колонок, номер первой строки таблицы и т.д.) и предварительной настройки. Просто выбираете файл эксель, документ 1С и нажимаете кнопку "Загрузить"

8000 руб.

09.11.2016    271088    1196    955    

1109

Оптовая торговля Рабочее место Создание на основании Бухгалтер Пользователь 1С:Предприятие 8 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 Россия Бухгалтерский учет Платные (руб)

Полнофункциональное расширение для формирования и ведения учета перевозочных документов всех видов (ТН, ТТН, ЭТрН). Печать документов или отправка через ЭПД (Электронный перевозочный документооборот). Поддержка регистрации нескольких перевозок на одну финансовую реализацию (в виде УПД, например), а также одной перевозки на основании нескольких финансовых реализаций. Формирование всех сопроводительных документов из одной отгрузки. Формирование реестра грузосопроводительных документов, доверенности менеджеров для указания ответственных лиц (руководитель, главный бухгалтер, кладовщик) организации для пользователей ИБ. Гибкая настройка функциональности под потребности организации.

3150 руб.

18.04.2017    53702    288    43    

99

Оптовая торговля Производство готовой продукции (работ, услуг) Розничная торговля Обмен с ГосИС Программист Бухгалтер Пользователь 1С:Предприятие 8 1C:Бухгалтерия Сельское хозяйство и рыболовство Розничная и сетевая торговля (FMCG) Оптовая торговля, дистрибуция, логистика Рестораны, кафе и фаст-фуд Пищевая промышленность Россия Бухгалтерский учет Управленческий учет Платные (руб)

Универсальная конфигурация Хамелеон Меркурий для взаимодействия с системой Меркурий (тестовый+рабочий+демо контур) может использоваться для интеграции в любую конфигурацию на базе 1С, версии ПРОФ и выше. Основное отличие от других решений - работа через веб-интерфейс и API 2.0(API 2.1). Для удобства реализован общий интерфейс в виде обработки, схожей с интерфейсом Меркурий, но возможностей гораздо больше, т.к. при интеграции в Вашу учетную систему, можно на основании Ваших справочников и документов, создавать соответствующие документы и справочники в системе Меркурий и наоборот.

5000 руб.

08.11.2017    128551    273    153    

402
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. roman3333 14.01.20 13:44 Сейчас в теме
добрый день! есть опыт автоматизации платежей..Т.е. клиент имеем неск-ко догворов. Оплачивает он общей суммой
Возможно ли как-то распределить автоматом общую сумму на все договры (от первого догвора до последнего)?
2. yurikmellon 6 14.01.20 14:35 Сейчас в теме
(1) добрый. А как Вы это себе представляете? Приходит выписка из банка по контрагенту (документ "Поступление на расчетный счет") на конкретную сумму и конкретный договор.
Потом что должно происходить? Эта сумма должна пропорционально распределиться на все договора данного контрагента?
3. roman3333 14.01.20 18:02 Сейчас в теме
допустим у клиента есть 7 договоров. К каждому договру привязан график ежемесячных платежей (дата/сумма). Соотв-но общая сумма распредел-ся согласно каждого договора и суммы из графика по порядку возрастания номеров договоров. Если общей суммы на все договоры не хватит,то на те договоры что не хватило суммы должны зафиксироваться как долг клиента по конкретному договору.
При следующем поступлении средств от клиента (выписка) вначале погашается долги по этим договорам,а затем плановые суммы из гарфика вновь распределяются.
4. yurikmellon 6 15.01.20 08:31 Сейчас в теме
(3) я бы в этом случае написал обработку, которая из одного документа "Поступление на расчетный счет" делает семь и сумму в этом документе распределяет по этим семи договорам в соответствии с графиком платежей начиная с первого по номеру. Нужно где то хранить информацию по долгам (регистр какой нибудь сделать), чтобы следующее поступление сначала закрывало эти долги. Как то так.
Для отправки сообщения требуется регистрация/авторизация