"Ввод на основании" в форме "Структуры подчиненности"

22.12.15

Разработка - Работа с интерфейсом

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

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

Вариант 1. С добавлением элементов на форму в режиме конфигуратора и добавлением программного кода.

Опишу по шагам:
1. Добавьте на форму "Структуры подчиненности" новые элементы управления Командная  панель и Табличное поле. Табличному полю сопоставьте реквизит типа ДокументСписок.ЛюбойТипДокумента, командной панели в качестве источника назначьте это табличное поле, установите свойство Автозаполнение = Истина. При этом на командной панели появятся стандартные кнопки, среди которых есть "Ввести на основании". Скопируйте эту кнопку и вставьте в самое начало.

2. Удалите новый элемент Табличное поле. При этом скопированная кнопка должна остаться на командной панели и свойство Автозаполнение = Истина.

3. Настройте положение, привязки, оформление командной панели как вам удобно. (Я предпочел разместить в правом верхнем углу.) Чтобы не было видно ненужные автокнопки, можно накрыть их поверх новой Панелью и тоже настроить привязки.

4. Вставьте программный код в двух местах.


В обработчике формы ПередОткрытием
    
   

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

В обработчике Процедура ДеревоДокументовПриАктивизацииСтроки(Элемент)

	ЭлементыФормы.СпискиДокументов.ТипЗначения = Новый ОписаниеТипов("ДокументСписок."+Элемент.ТекущиеДанные.Ссылка.метаданные().Имя);
	ЭлементыФормы.СпискиДокументов.ТекущаяСтрока = Элемент.ТекущиеДанные.Ссылка;


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

Вариант 2. Полностью программный способ.


Вставьте программный код в двух местах.


В обработчике формы ПередОткрытием

	Если ЭлементыФормы.Найти("СпискиДокументов") = Неопределено Тогда
		ТабличноеПолеСписок = ЭлементыФормы.Добавить(Тип("ТабличноеПоле"), //Тип элемента
		"СпискиДокументов", //Имя
		Ложь, //Видимость 
		); // Расположение, родитель
		
		КПВводаНаОсновании = ЭлементыФормы.Добавить(Тип("КоманднаяПанель"), //Тип элемента
		"КоманднаяПанельВводаНаОсновании", //Имя
		Истина, //Видимость 
		); // Расположение, родитель
		
		
		КПВводаНаОсновании.Верх = 0;
		КПВводаНаОсновании.Лево = Этаформа.Ширина - 53;
		КПВводаНаОсновании.Ширина = 53;
		КПВводаНаОсновании.Высота = 25;
		КПВводаНаОсновании.ЦветФона = ЦветаСтиля.ЦветФонаКнопки;
		КПВводаНаОсновании.Рамка = Новый Рамка(ТипРамкиЭлементаУправления .Подчеркивание,1);
		КПВводаНаОсновании.Вспомогательная = Истина;
		КПВводаНаОсновании.ПорядокОбхода = 2;
		КПВводаНаОсновании.Доступность = Истина;

		
		НоваяКнопка = КПВводаНаОсновании.Кнопки.Добавить("ПодменюВводНаОсновании", ТипКнопкиКоманднойПанели.Подменю, "На основании");
		НоваяКнопка.Подсказка = "Ввести на основании";
		НоваяКнопка.Пояснение = "Выбор объекта, которого необходимо заполнить на основании данного объекта";
		НоваяКнопка.Отображение =  ОтображениеКнопкиКоманднойПанели.Авто;
		НоваяКнопка.Картинка = БиблиотекаКартинок.ВводНаОсновании;
		
		КПВводаНаОсновании.Автозаполнение = Истина;
		КПВводаНаОсновании.ИсточникДействий = ТабличноеПолеСписок; 
		
		
		КПВводаНаОсновании.УстановитьПривязку(ГраницаЭлементаУправления.Низ,
		КПВводаНаОсновании,
		ГраницаЭлементаУправления.Низ);
		КПВводаНаОсновании.УстановитьПривязку(ГраницаЭлементаУправления.Лево,
		КПВводаНаОсновании,
		ГраницаЭлементаУправления.Право);
		КПВводаНаОсновании.УстановитьПривязку(ГраницаЭлементаУправления.Право,
		ЭтаФорма.Панель,
		ГраницаЭлементаУправления.Право);
		
		
		ПДляВводаНаОсновании = ЭлементыФормы.Добавить(Тип("Панель"), //Тип элемента
		"ПанельДляВводаНаОсновании", //Имя
		Истина, //Видимость 
		); // Расположение, родитель
		
		ПДляВводаНаОсновании.Верх = 0;
		ПДляВводаНаОсновании.Лево = Этаформа.Ширина - 20;
		ПДляВводаНаОсновании.Ширина = 20;
		ПДляВводаНаОсновании.Высота = 25;
		ПДляВводаНаОсновании.ЦветФона = ЦветаСтиля.ЦветФонаКнопки;
		ПДляВводаНаОсновании.Рамка = Новый Рамка(ТипРамкиЭлементаУправления .Подчеркивание,1);
		ПДляВводаНаОсновании.ОтображениеЗакладок = ОтображениеЗакладок .НеИспользовать;
		ПДляВводаНаОсновании.ПорядокОбхода = 3;
		
		
		ПДляВводаНаОсновании.УстановитьПривязку(ГраницаЭлементаУправления.Низ,
		ПДляВводаНаОсновании,
		ГраницаЭлементаУправления.Низ);
		ПДляВводаНаОсновании.УстановитьПривязку(ГраницаЭлементаУправления.Лево,
		ПДляВводаНаОсновании,
		ГраницаЭлементаУправления.Право);
		ПДляВводаНаОсновании.УстановитьПривязку(ГраницаЭлементаУправления.Право,
		ЭтаФорма.Панель,
		ГраницаЭлементаУправления.Право);
	
	КонецЕсли;

В обработчике Процедура ДеревоДокументовПриАктивизацииСтроки(Элемент)

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

 

 

Всё. Наслаждайтесь удобной функцией! :)


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

См. также

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

Создайте свой функциональный интерфейс в любой конфигурации 1С с помощью расширения Infostart Dashboard. Настраивайте панели виджетов с метриками, индикаторами и показателями на начальном экране. Узнайте возможность внедрения подсистемы у себя в конфигурации с помощью бесплатной обработки "Анализ внедрения подсистемы 1С Infostart Dashboard"!

31720 руб.

27.03.2025    76742    50    38    

60

Адаптация типовых решений 1С:Предприятие 8 1С:Документооборот Россия Платные (руб)

Расширение конфигурации для «1С:Документооборот КОРП», редакция 3.0. позволяет: 1.использовать произвольные табличные части в качестве дополнительных реквизитов к документу; 2 использовать произвольные табличные части в шаблонах в формате docx для автоматического заполнения таблиц.

32330 руб.

29.06.2023    11500    34    15    

41

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

Расширение позволяет вывести в табличном документе факсимиле печати и подписей и/или вывести произвольную картинку из прикреплённых файлов организации для 1С УТ 11.5, КА 2.5, ERP 2.5, УНФ 3, Розница 3. Вывод факсимиле возможен в табличные документы УПД, УКД, Счёт-фактура, ТОРГ-12 и другие. Возможно настроить вывод для любых типовых макетов (Акт сверки, М-15, ТТН), для этого потребуется отредактировать макет и разместить на нём картинки с соответствующими именами, при выводе на печать в размещённые картинки будут выводиться факсимиле из прикреплённых рисунков. Редактирование осуществляется через типовой механизм в пользовательском интерфейсе.

5500 руб.

07.02.2023    12343    115    20    

71

Разработка Инструментарий разработчика Работа с интерфейсом Адаптация типовых решений Нейросети 1C:Бухгалтерия 1C:ERP 1С:ЗУП 1С:КА 1С:УНФ 1С:УТ 1С:Розница 1С:ДО 1С:ERP Управление предприятием 2 Платные (руб)

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

36600 руб.

28.08.2025    6947    2    2    

6

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

Расширение "Дополнительные документы" предназначено для создания дополнительных документов различного назначения, как форм для внесения данных так и печатных форм в расширяемой конфигурации пользовательскими средствами, без работы в конфигураторе и внесения изменений в структуру данных. Тестировалось для "1С:БП", "1С:УНФ","1С:КА"

21859 руб.

29.12.2025    967    1    8    

2

Банковские операции Адаптация типовых решений Бухгалтер Пользователь 1С:Предприятие 8 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет Платные (руб)

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

9760 руб.

17.06.2025    2924    8    0    

8

Работа с интерфейсом Системный администратор Программист 1С:Предприятие 8 1C:Бухгалтерия Платные (руб)

Расширение «Динамическое управление доступом к элементам форм объектов 1С8» предназначен для обеспечения возможности оперативного управления видимостью и доступностью элементов форм документов и справочников продуктов фирмы «1С» «1С:Предприятие 8». Решение универсальное, встраивается в любую конфигурацию с минимальными доработками, что позволяет без проблем обновлять типовые решения.

6100 руб.

14.01.2016    59847    22    25    

47

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

Знакомая ситуация? Пользователи, особенно менеджеры, уверены: отборов много не бывает. Идут пожелания добавить в форму списка еще один быстрый фильтр, еще два, еще пять... В итоге интерфейс превращается в нагромождение полей отбора, а потребность в «самом главном» отборе, который «вот прямо сейчас нужен», все равно не закрыта. Универсальное расширение, которое решает эту проблему элегантно и технологично. С его помощью в любую форму списка можно легко добавить панель настраиваемых кнопок-закладок, каждая из которых применяет сложный фильтр-запрос, а так же показывает актуальное количество элементов в реальном времени.

6088 руб.

17.10.2025    1764    3    0    

2
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. help1Ckr 31.07.13 09:47 Сейчас в теме
Печаль, что нельзя добавить не меняя конфигурацию. А так за старания плюс
2. Pim 190 22.12.15 07:07 Сейчас в теме
Зачем во 2-ом варианте строка "ИндексКнопки = КнопкиКПВводаНаОсновании.индекс(КПВводаНаОсновании);"?
3. zaxarovsky 111 22.12.15 11:43 Сейчас в теме
(2) Pim, О! Спасибо за поправку! Это лишнее, не заметил. Удалю...
4. jef_infostart 10 18.06.21 15:48 Сейчас в теме
Годно. Сделал по первому варианту, только дополнительную панель кинул прям на дерево и сделал невидимой. Заполнил её всем чем надо и прописал в контекстное меню дерева. Работает, бухи довольны как слоны. Спасибо.
Для отправки сообщения требуется регистрация/авторизация