Изменение реквизитов существующих объектов (документов) 1С без сохранения

14.06.19

Задачи пользователя - Корректировка данных

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

Скачать файл

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

Наименование По подписке [?] Купить один файл
Изменение реквизитов объектов 1С без проведения (база):
.rar 45,37Kb ver:1
5
5 Скачать (1 SM) Купить за 1 850 руб.
Изменение реквизитов объектов 1С без проведения (конфигурация):
.cf 20,11Kb ver:1
0
0 Скачать (1 SM) Купить за 1 850 руб.

Предвосхищая предложения коллег, спешу ответить на вопрос, - почему не воспользоваться стандартным механизмом БСП дополнительных сведений и реквизитов?

Дело в том, что сотрудники компании – это пользователи, которым надо, помимо прочего, чтобы поле дополнительных реквизитов было в определенном месте на основной форме элемента.

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

Привожу пример изменения конфигурации.

Нам потребуется добавить регистр сведений - «ДополнительныеРеквизитыДокументов».

Свойства регистра: Непериодический, независимый.

Независимым его необходимо сделать, т.к. объектами  с дополнительным реквизитом может быть любой объект – Документ, Справочник, План счетов или ПВХ.

Измерения:

  • ДокументСсылка – имеющий тип, объекты для которых необходим реквизит;

Синоним «Документ»

Ресурсы:

  • ОригиналПолучен – тип «Булево»;

Синоним «Оригинал получен»

В модуле менеджера накидываем процедуры и функции для работы с записями регистра

// Формирует структуру записи регистра
//
// Параметры:
//
// Возвращаемое значение:
//   <Структура>   - структурированные параметры записи регистра
//
Функция ПолучитьСтруктуруРегистра() Экспорт

                Возврат Новый Структура("ДокументСсылка, ОригиналПолучен");

КонецФункции // ПолучитьСтруктуруРегистра()

// <Производит запись в регистр по заданой структуре
//
// Параметры:
//  <СтруктураЗаписи>  - <Структура> - структурированные параметры записи регистра
//
// Возвращаемое значение:
//   <Булево>   - признак успешной операции
//
Функция ЗаписатьВРегистрПоСтруктуре(СтруктураЗаписи) Экспорт

                Успех = Истина;

                ЗаписьРегистра = РегистрыСведений.ДополнительныеРеквизитыДокументов.СоздатьМенеджерЗаписи();
                ЗаполнитьЗначенияСвойств(ЗаписьРегистра, СтруктураЗаписи);
                Попытка
                               ЗаписьРегистра.Записать(Истина);
                Исключение
                               ОписаниеОшибки = ОписаниеОшибки();
                               Успех = Ложь;
                               Сообщение = Новый СообщениеПользователю;
                               Сообщение.Текст = ОписаниеОшибки;
                               Сообщение.Сообщить();
                КонецПопытки;

                Возврат Успех;

КонецФункции // ЗаписатьВРегистрПоСтруктуре()

// <Заполняет структуру полученными из базы параметрами>
//
// Параметры:
//  <СтруктураЗаписи>  - <Структура> - структурированные параметры записи регистра
//
Процедура ПолучитьДополнительныеРеквизитаДокумента(СтруктураЗаписи) Экспорт

                Если Не ЗначениеЗаполнено(СтруктураЗаписи["ДокументСсылка"]) Тогда
                               СтруктураЗаписи["ОригиналПолучен"] = Ложь;
                               Возврат;
                КонецЕсли;
                Запрос = Новый Запрос;
                Запрос.Текст = "ВЫБРАТЬ

                               |             ДополнительныеРеквизитыДокументов.ДокументСсылка КАК ДокументСсылка,

                               |             ДополнительныеРеквизитыДокументов.ОригиналПолучен КАК ОригиналПолучен

                               |ИЗ

                               |             РегистрСведений.ДополнительныеРеквизитыДокументов КАК ДополнительныеРеквизитыДокументов

                               |ГДЕ

                               |             ДополнительныеРеквизитыДокументов.ДокументСсылка = &ДокументСсылка";

                // Установка параметров
                Запрос.УстановитьПараметр("ДокументСсылка", СтруктураЗаписи["ДокументСсылка"]);
                // Выполнение запроса
                Результат = Запрос.Выполнить();
                // Проверка результатов
                Если НЕ Результат.Пустой() Тогда
                               Выборка = Результат.Выбрать();
                               Выборка.Следующий();
                               ЗаполнитьЗначенияСвойств(СтруктураЗаписи, Выборка);
                Иначе
                               СтруктураЗаписи["ОригиналПолучен"] = Ложь;
                КонецЕсли;

КонецПроцедуры // ПолучитьДополнительныеРеквизитаДокумента()

 

Основной функционал для работы с регистром готов. Теперь надо внести изменения в модули форм объектов.

 

В форме объекта изменяю процедуру «ПриСозданииНаСервере»

&НаСервере
Процедура ПриСозданииНаСервере(Отказ, СтандартнаяОбработка)

                //...
                // Различный код типовых конфигураций
                //...

                // Доработка под дополнительный реквизит
                
                мРеквизитыДобавить = Новый Массив;
                Реквизит = Новый РеквизитФормы("Доп_ОригиналПолучен", Новый ОписаниеТипов("Булево"), "", "Оригинал получен", Ложь);
                мРеквизитыДобавить.Добавить(Реквизит);
                ИзменитьРеквизиты(мРеквизитыДобавить);
                НовыйЭлем = Элементы.Добавить("ФормаДоп_ОригиналПолучен", Тип("ПолеФормы"));
                НовыйЭлем.Вид = ВидПоляФормы.ПолеФлажка;
                НовыйЭлем.ПутьКДанным = "Доп_ОригиналПолучен";
                НовыйЭлем.Заголовок = "Оригинал получен";
                НовыйЭлем.ПоложениеЗаголовка = ПоложениеЗаголовкаЭлементаФормы.Авто;
                НовыйЭлем.УстановитьДействие("ПриИзменении", "Обработчик_ОригиналПолученПриИзменении");
                Если ЗначениеЗаполнено(Объект.Ссылка) Тогда
                               СтруктураЗаписи = РегистрыСведений.ДополнительныеРеквизитыДокументов.ПолучитьСтруктуруРегистра();
                               СтруктураЗаписи["ДокументСсылка"] = Объект.Ссылка;
                РегистрыСведений.ДополнительныеРеквизитыДокументов.ПолучитьДополнительныеРеквизитаДокумента(СтруктураЗаписи);
                               ЭтаФорма["Доп_ОригиналПолучен"] = СтруктураЗаписи["ОригиналПолучен"];
                КонецЕсли;
                
                // конец

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

 

Вношу изменения в процедуру «ПослеЗаписи»

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

                //...
                // Различный код типовых конфигураций
                //...
               
                // Доработка под дополнительный реквизит

                Подключаемый_ЗаписатьДополнительныеРеквизитыНаКлиенте();

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

 

Дописываю свои процедуры и обработчики в этой же форме объекта

&НаКлиенте
Процедура Обработчик_ОригиналПолученПриИзменении(Элемент)

                Если Не ЗначениеЗаполнено(Объект.Ссылка) Тогда
                    Возврат;
                КонецЕсли;
                Подключаемый_ЗаписатьДополнительныеРеквизитыНаКлиенте();

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

&НаКлиенте
Процедура Подключаемый_ЗаписатьДополнительныеРеквизитыНаКлиенте()

                Подключаемый_ЗаписатьДополнительныеРеквизитыНаСервере();
                ОповеститьОбИзменении(Объект.Ссылка);

КонецПроцедуры // Подключаемый_ЗаписатьДополнительныеРеквизитыНаКлиенте()

&НаСервере
Процедура Подключаемый_ЗаписатьДополнительныеРеквизитыНаСервере()

                СтруктураЗаписи = РегистрыСведений.ДополнительныеРеквизитыДокументов.ПолучитьСтруктуруРегистра();
                СтруктураЗаписи["ДокументСсылка"] = Объект.Ссылка;
                СтруктураЗаписи["ОригиналПолучен"] = ЭтаФорма["Доп_ОригиналПолучен"];
                РегистрыСведений.ДополнительныеРеквизитыДокументов.ЗаписатьВРегистрПоСтруктуре(СтруктураЗаписи);

КонецПроцедуры // Подключаемый_ЗаписатьДополнительныеРеквизитыНаСервере()

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

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

В форме списка изменяю процедуру «При созданииНаСервере»

&НаСервере
Процедура ПриСозданииНаСервере(Отказ, СтандартнаяОбработка)

                //...
                // Различный код типовых конфигураций
                //...

                // Доработка под дополнительный реквизит

                Список.ТекстЗапроса = Подключаемый_ПолучитьТекстЗапросаНаСервере();
                НовыйЭлем = Элементы.Добавить("Доп_ОригиналПолучен", Тип("ПолеФормы"), Элементы.Список);
                НовыйЭлем.Вид = ВидПоляФормы.ПолеФлажка;
                НовыйЭлем.ПутьКДанным       = "Список.ОригиналПолучен";
                НовыйЭлем.Заголовок               = "Оригинал получен";

                //конец

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

 

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

&НаСервереБезКонтекста
Функция Подключаемый_ПолучитьТекстЗапросаНаСервере()

                Возврат "ВЫБРАТЬ
                        |    ДокументДокументТест.Ссылка КАК Ссылка,
                        |    ДокументДокументТест.ПометкаУдаления КАК ПометкаУдаления,
                        |    ДокументДокументТест.Номер КАК Номер,
                        |    ДокументДокументТест.Дата КАК Дата,
                        |    ДокументДокументТест.Проведен КАК Проведен,
                        |    ДокументДокументТест.ТектовыйРеквизит КАК ТектовыйРеквизит,
                        |    ДокументДокументТест.МоментВремени КАК МоментВремени,
                        |    ЕСТЬNULL(ДополнительныеРеквизитыДокументов.ОригиналПолучен, ЛОЖЬ) КАК ОригиналПолучен
                        |ИЗ
                        |    Документ.ДокументТест КАК ДокументДокументТест
                        |                    ЛЕВОЕ СОЕДИНЕНИЕ РегистрСведений.ДополнительныеРеквизитыДокументов КАК ДополнительныеРеквизитыДокументов
                        |                    ПО ДополнительныеРеквизитыДокументов.ДокументСсылка = ДокументДокументТест.Ссылка";

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

 

Данное решение можно тиражировать. При необходимости, требуется не много времени для реализации и добавления в другие объекты.

Пример реализации приведен в базе, которая доступна для скачивания. Реализация для платформы 8.3.13 и выше.

Изменение реквизитов без проведения дополнительные сведения объектов разработка модернизация конфигурация

См. также

Корректировка данных Зарплата Бухгалтер Платформа 1С v8.3 Сложные периодические расчеты 1С:Зарплата и кадры бюджетного учреждения 1С:Зарплата и Управление Персоналом 3.x Россия Бухгалтерский учет НДФЛ Платные (руб)

Обработка исправляет технические ошибки по НДФЛ, взаиморасчетам с сотрудниками в 1С:ЗУП (1С:ЗКГУ) на начало года. Фактически все ошибки, которые проявляются в ведомостях на выплату, расчетных листках, при заполнении ведомостей на выплату и отчетах 6-НДФЛ и т.д. нужно начинать исправлять с начала расчетного года. Это позволит быть уверенными, что после завершения расчетов предыдущего года, начали работать с «чистого листа» без ошибочных остатков.

60000 руб.

06.10.2023    5415    38    20    

46

Закрытие периода Инструменты администратора БД Корректировка данных Бухгалтер Пользователь Бухгалтерский учет 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет Платные (руб)

Расширение «Оперативное проведение» в 4 раза уменьшает время проведения документов и закрытия месяца. Является комплексным решением проблем 62 и 60 счетов. Оптимизирует проведение при включенной функциональной опции «Раздельный учет НДС». Используется в более 10 организациях уже 2 года. Совместимо с конфигурацией Бухгалтерия 3.0 (+КОРП).

14400 руб.

29.04.2020    34930    112    152    

77

Корректировка данных Системный администратор Программист Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Платные (руб)

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

3600 руб.

10.02.2017    112355    679    175    

717

Корректировка данных Программист Бухгалтер Пользователь Платформа 1С v8.3 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет НДС Платные (руб)

Обработка предназначена для ООО для смены системы налогообложения УСН на ОСНО, без ведения раздельного учета, входящего НДС по способам учета. При реализации перехода в операции формируются проводки по выделению НДС, который ранее учитывался в стоимости номенклатуры, регистр «НДС Предъявленный».

6000 руб.

22.01.2025    1043    3    0    

5

Корректировка данных Бухгалтер Платформа 1С v8.3 Бухгалтерский учет 1С:Бухгалтерия 3.0 Бухгалтерский учет Налоговый учет Налог на прибыль Платные (руб)

Обработка служит для: выравнивания бухгалтерского и налогового учета на определенную дату по выбранным счетам; закрытия остатков по выбранным счетам; обнуления налогового учета (ПР, ВР также будут обнулены)

2880 руб.

05.05.2024    884    13    0    

9

Корректировка данных Ценообразование, анализ цен Мастера заполнения Пользователь Платформа 1С v8.3 1С:Управление торговлей 11 Россия Управленческий учет Платные (руб)

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

2400 руб.

27.06.2023    2868    3    0    

3

Банковские операции Корректировка данных Бухгалтер Платформа 1С v8.3 Бухгалтерский учет 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет Платные (руб)

При загрузке банковской выписки поступлений по платежным картам 1С не совсем верно распознает данные, предоставляемые банком. В результате приходится корректировать эти данные вручную в документе "Поступление на расчетный счет". Ставить сумму комиссии (даже когда программа автоматом рассчитала сумму она не всегда совпадает с банком), вид операции, в зависимости от торговой точки менять учет налогов, ставить договор итд. Все это настраивается один раз и вам останется только выбрать период! Есть и простой вариант использования - просто правит сумму комиссии. Расширение в комплекте позволяет вызвать обработку автоматически после загрузки выписки.

4200 руб.

23.12.2021    15760    10    26    

15

Кассовые операции Корректировка данных Бухгалтер Платформа 1С v8.3 Оперативный учет 1С:Управление торговлей 11 Бухгалтерский учет Платные (руб)

Создание, редактирование и удаление документов "Выемка ДС из Кассы ККМ" в конфигурации 1С:Управление торговлей 11. Групповая обработка Выемок. Редактирование регистра накопления "Денежные средства в кассе ККМ".

2000 руб.

20.11.2018    30147    16    2    

16
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. VmvLer 14.06.19 15:10 Сейчас в теме
- создать обработку с выбором дополнительных реквизитов или сведения объектов.
- записывать только их.
2. BraunAlex 137 14.06.19 16:35 Сейчас в теме
(1)
или сведения объектов

А на форму в нужное место? Все равно конфигу менять.
3. VmvLer 14.06.19 16:37 Сейчас в теме
есть расширения же
для эстетов в последних платформах создали всплывающие формы
4. BraunAlex 137 14.06.19 16:56 Сейчас в теме
(3)
есть расширения же


А кто против?
Чем больше вариантов решения тем лучше
5. par_62 15.06.19 20:05 Сейчас в теме
По моему не надо огород городить, а создать отдельную форму длкумента и воспользоватьмя БСП шными доп реквизитами и идентификаторами для разработчиков ( ежели таковая есть).
Добавить свою пописку на процедуру менеджера документа по получению формы. Создать привязки форм к пользователям. А в этой форме уже размещать доп реквизиты и т.п. как угодно.
6. BraunAlex 137 16.06.19 08:09 Сейчас в теме
(5)
По моему не надо огород городить, а создать отдельную форму длкумента

В стандартных конфигурациях в модуле формы может быть типовой код. Строк типового кода может быть от 0 до ОченьМногоСтрокКода. Их надо поддерживать и не терять типовую функциональность от дистрибьютора.

Твое предложение увеличивает расходы на поддержку конфигурации, Даже если это будет расширение.
7. par_62 16.06.19 12:04 Сейчас в теме
Ок. Но есть и обратная сторона. Обычно кроме этих реквизитов в дальнейшем потребуется и доп функционал. По крайней мере, в моей практике это постоянно. Начинается также как описал аатор, а затем входят во вкус- нужны доп контроли, регистрации и тому подобное. Согласен,если использовать описанное в статье к общим вопросам ,тогда может и так
8. BraunAlex 137 16.06.19 23:24 Сейчас в теме
(7)
а затем входят во вкус- нужны доп контроли, регистрации и тому подобное

Аппетит приходит во время еды.
Я не претендую на "Самое крутое решение". Это один из вариантов, который пока что работает (уже более года)
9. telo71 10 06.09.20 14:58 Сейчас в теме
Спасибо, достаточно просто и недурно работает!
Оставьте свое сообщение