БСП: инструкция подключения объектов к подсистеме запрета редактирования реквизитов

24.10.24

Разработка - БСП (Библиотека стандартных подсистем)

В статье описан алгоритм для включения документа или справочника в систему БСП. Будет полезно программистам 1С, начинающим работать с БСП.

Содержание

  1. Включение документа или справочника
  2. Внесение изменений в форму
  3. Важно обратить внимание
  4. Примеры функций и процедура

 

Справка: для предупреждения необдуманного изменения «ключевых» реквизитов формы документа или справочника создана подсистема Запрет редактирования реквизитов объектов. Описание работы есть на сайте ИТС: https://its.1c.ru/db/bsp3110doc#content:2329:hdoc

 

Для включения нашего документа или справочника выполняем:

  1. Подключим наш документ или справочник к подсистеме: в процедуре ЗапретРедактированияРеквизитовОбъектовПереопределяемый.ПриОпределенииОбъектовСЗаблокированнымиРеквизитами добавляем строку, аналогично уже заполненным: Объекты.Вставить(Метаданные.<"Документы" или "Справочники">.<Наименование документа или справочника>.ПолноеИмя(), "ПолучитьБлокируемыеРеквизитыОбъекта");
  2. Определим список блокируемых реквизитов: в модуле менеджера добавляемого объекта создаем функцию ПолучитьБлокируемыеРеквизитыОбъекта. Функция должна возвращать массив строк с именами реквизитов формы, объекта и табличных частей, которые предполагается запретить для редактирования. Текст функции можно подсмотреть в других справочниках и документах, добавленных в подсистему ранее. Пример функции ниже — см. пример 1.

 

Вносим изменения в форму:

  1. В процедуре ПриСозданииНаСервере требуется добавить вызов общей процедуры ЗапретРедактированияРеквизитовОбъектов.ЗаблокироватьРеквизиты(ЭтотОбъект);
  2. В процедуре ПослеЗаписиНаСервере добавляем ту же строку.
  3. Добавляем процедуру Подключаемый_РазрешитьРедактированиеРеквизитовОбъекта(Команда). Текст процедуры можно скопировать из объектов, добавленных в подсистему ранее. Пример функции ниже — см. пример 2. Есть несколько вариантов работы с разрешением редактирования реквизитов. Можно просто по кнопке «Разрешить редактирование реквизитов» открывать возможность изменения реквизитов, либо открывать отдельное окно с возможностью выбора нужных реквизитов и особыми предупреждениями по изменению отдельных реквизитов. Для обоих данных случаев есть примеры процедур ниже — см. пример 2.
  4. Описываем процедуру "Подключаемый_РазрешитьРедактированиеРеквизитовОбъектаЗавершение". Обратите внимание, что эта процедура экспортная. Пример 3
  5. Если решили добавить отдельную форму РазблокированиеРеквизитов – в качестве основы можно взять уже используемую форму документа или справочника, ранее используемого в подсистеме.
  6. Не забудьте обязательно внести следующие изменения:

— Каждый блокируемый реквизит размещаем как реквизит формы с типом Булево и размещаем на форме

— Создаем две кнопки "РазрешитьРедактирование" и "Закрыть"

— Если требуется дополнительно описать предупреждения пользователю - добавляем

— В процедуре ПриСозданииНаСервере каждому реквизиту устанавливаем значение "Истина"

— В процедуре кнопки "РазрешитьРедактирование" проверяем значение реквизитов формы, соответствующих блокируемым реквизитам и создаем массив "Результат". В массив помещаем реквизиты, которые требуется разблокировать. Последняя команда "Закрыть(Результат)". Пример процедуры ниже см. пример 4.

 

Обратите внимание, что

— на некоторых формах документа в качестве табличной части может показываться и табличная часть документа и дополнительный реквизит формы с дополнительными данными. В таком случае в функции ПолучитьБлокируемыеРеквизитыОбъекта указываем строку "Результат.Добавить("Товары;ТоварыПоПериодам"). После наименования таблицы "Товары" указываем имя элемента на форме "ТоварыПоПериодам".

— при блокировании поля периода - если блокировать поля "ДатаНачала" и "ДатаОкончания", то блокируются сами поля, но не стандартная кнопка установки периода. В таком случае рекомендуется добавить в список блокируемых  добавить элемент "УстановитьИнтервал".  В таком случае в функции ПолучитьБлокируемыеРеквизитыОбъекта указываем строку "Результат.Добавить("НачалоПериода;УстановитьИнтервал").

В обоих случаях изменять форму РазблокированиеРеквизитов не требуется.

Следующая особенность нужна. Если требуется блокировать совместно с каким-то реквизитом кнопки, например: "Провести и закрыть", "Записать" и "Провести". Для этого в функции ПолучитьБлокируемыеРеквизитыОбъекта добавляем к блокируемому реквизиту наименования элементов формы, которые нужно заблокировать совместно. Например: "Результат.Добавить("Статус;ФормаПровестиИЗакрыть, ФормаЗакрыть, ФормаПровести");"

 

Примеры функций и процедура

Пример 1. Функция ПолучитьБлокируемыеРеквизитыОбъекта

Результат = Новый Массив;
Результат.Добавить("Статус");
Результат.Добавить("Сценарий");
Результат.Добавить("ВидПлана");
Возврат Результат;
КонецФункции

 

Пример 2. Если просто разрешаем редактирование реквизитов

&НаКлиенте
Процедура Подключаемый_РазрешитьРедактированиеРеквизитовОбъекта(Команда)
Оповещение = Новый ОписаниеОповещения("Подключаемый_РазрешитьРедактированиеРеквизитовОбъектаЗавершение", ЭтотОбъект);
ОбщегоНазначенияКлиент.РазрешитьРедактированиеРеквизитовОбъекта(ЭтотОбъект,, Оповещение);
КонецПроцедуры

 

Пример 2. Если требуется открыть особое окно с выбором открываемых реквизитов и предупреждениями об открытии. Не забудьте, что в данном случае саму форму с названием "РазблокированиеРеквизитов" требуется сформировать самим в формах создаваемого объекта.

&НаКлиенте
Процедура Подключаемый_РазрешитьРедактированиеРеквизитовОбъекта(Команда)
Если НЕ Объект.Ссылка.Пустая() Тогда
ОткрытьФорму("<"Справочник" или "Документ">.<Наименование документа или справочника>.Форма.РазблокированиеРеквизитов",,,,,,
РежимОткрытияОкнаФормы.БлокироватьОкноВладельца);
КонецЕсли
КонецПроцедуры

 

Пример 3. Если после установки разблокировки реквизитов требуется установить доступность других элементов на форме. Обычно это указывается в процедуре УстановитьДоступностьПолей() – в таком случае не забудьте добавить её в конец добавляемой процедуры.  В примере ниже эта строка закомментирована:

&НаКлиенте
Процедура Подключаемый_РазрешитьРедактированиеРеквизитовОбъектаЗавершение(Результат, ДополнительныеПараметры) Экспорт
Если ТипЗнч(Результат) = Тип("Массив") И Результат.Количество() > 0 Тогда
ЗапретРедактированияРеквизитовОбъектовКлиент.УстановитьДоступностьЭлементовФормы(ЭтотОбъект, Результат);
//УстановитьДоступностьПолей();
КонецЕсли;
КонецПроцедуры

 

Пример 4. 

&НаКлиенте
Процедура РазрешитьРедактирование(Команда)
Результат = Новый Массив;
Если РазрешитьРедактированиеСтатус Тогда
Результат.Добавить("Статус");
КонецЕсли
Если РазрешитьРедактированиеТовары Тогда
Результат.Добавить("Товары");
КонецЕсли
Если РазрешитьРедактированиеПериода Тогда
Результат.Добавить("ДатаНачала");
Результат.Добавить("ДатаОкончания");
КонецЕсли
Закрыть(Результат);
КонецПроцедуры

 

Автор: Михаил Х.

См. также

БСП (Библиотека стандартных подсистем) Программист Платные (руб)

Синтакс-помощник БСП - cправочник по библиотеке стандартных подсистем. В состав справочника входит описание экспортных процедур и функций, размещенных в областях кода ПрограммныйИнтерфейс БСП.

1800 руб.

21.11.2024    3294    15    16    

17

БСП (Библиотека стандартных подсистем) Программист Платформа 1С v8.3 Бесплатно (free)

Расскажу, как использовать полезный функционал - инструментарий разработчика «1С:Библиотека стандартных подсистем» (БСП) в своих объектах метаданных. Статья будет полезна как шпаргалка при написании собственных объектов метаданных.

27.12.2024    2106    PROSTO-1C    12    

32

БСП (Библиотека стандартных подсистем) Программист Бесплатно (free)

Синтакс-помощник БСП - справочник по Библиотеке Стандартных Подсистем, профессиональный инструмент разработчика с интуитивно понятным интерфейсом. Читайте в статье как использовать все возможности справочника и сделать работу с БСП более комфортной и эффективной.

11.12.2024    3670    gorenski    0    

8

БСП (Библиотека стандартных подсистем) Менеджеры внешних отчетов Программист Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Управление холдингом Абонемент ($m)

За последние лет 5 несколько раз сталкиваюсь с проблемой на разных проектах (в конфигурациях 1С:ERP, 1С:ERP УХ и многих других, основанных на БСП), когда много пользователей (около 30 тысяч) в информационной базе, время добавления доступа для пользователей занимает значительное время. Открытие списка занимает от 10 до 15 секунд, и каждое изменение списка еще примерно столько же.

1 стартмани

10.12.2024    889    Iaskeliainen    2    

7

БСП (Библиотека стандартных подсистем) Программист Платформа 1С v8.3 Бесплатно (free)

Некоторые нюансы, если вы захотите создавать свои расширения. Доработка отчета "Связанные документы" для отражения документов расширения. Печатные формы с шаблоном Word.

20.11.2024    3110    milkers    3    

10

БСП (Библиотека стандартных подсистем) Работа с интерфейсом Программист Платформа 1С v8.3 Бесплатно (free)

В материале описан универсальный механизм работы с добавленными элементами на общую форму «ФормаОтчета». Думаю, облегчит работу многим разработчикам.

08.10.2024    1290    PROSTO-1C    4    

14

БСП (Библиотека стандартных подсистем) Программист Стажер Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

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

04.10.2024    2183    MadRave    11    

26
Оставьте свое сообщение