Добавление собственного виджета в 1С:Документооборот

14.12.19

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

В данной публикации я хочу описать процесс добавления собственного виджета для функционала отсутствий в 1С документооборот.

Доработка выполнялась по инструкции с ИТС (ссылка на инструкцию с ИТС).

1) В справочник "Виджеты" необходимо добавить собственный предопределенный элемент:

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

 
 Код в функции "ДоступныеВиджеты" модуля менеджера справочника "Виджеты"

 2) В справочник "ПоказателиВиджетов" необходимо добавить собственные предопределенные элементы:

В созданных показателях необходимо заполнить реквизит "Виджет" в предприятии или с помощью обработчика обновления / обработки.

3) Далее необходимо добавить процедуру для заполнения собственного виджета в общий модуль "ТекущиеДелаДокументооборотСервер":

 
 Код заполнения собственного виджета

 

// Заполняет виджет Отсутствия в форме Текущие дела.
//
// Параметры:
//   Параметры - Структура
//                  - Форма - УправляемаяФорма - форма Текущие дела.
//                  - ИндексВиджета - Строка - индекс виджета в форме.
//                  - ТекущаяДатаСеанса - Дата - текущая дата сеанса.
//                  - ТекущийПользователь - СправочникСсылка.Пользователи - Ссылка на текущего пользователя.
Процедура пп_ЗаполнитьВиджетОтсутствия(Параметры) 
	
	Форма = Параметры.Форма;
	ИндексВиджета = Параметры.ИндексВиджета;
	ТекущаяДата = Параметры.ТекущаяДатаСеанса;
	ТекущийПользователь = Параметры.ТекущийПользователь;
	
	ЦветТекста_Обычный = ЦветТекста_Обычный();
	ЦветаВиджета = ЦветаВиджета(ИндексВиджета);
	
	Запрос = Новый Запрос; 	
	Запрос.Текст = "ВЫБРАТЬ
	|	КОЛИЧЕСТВО(РАЗЛИЧНЫЕ Отсутствие.Ссылка) КАК КоличествоОтсутствий
	|ИЗ
	|	Документ.Отсутствие КАК Отсутствие
	|ГДЕ
	|	Отсутствие.ДатаНачала <= &ДатаОкончания И Отсутствие.ДатаОкончания >= &ДатаНачала
	|	И Отсутствие.ПометкаУдаления = ЛОЖЬ";
	
	//За месяц
	Запрос.УстановитьПараметр("ДатаНачала", НачалоМесяца(ТекущаяДата));
	Запрос.УстановитьПараметр("ДатаОкончания", КонецМесяца(ТекущаяДата));
	
	Выборка = Запрос.Выполнить().Выбрать();
	Выборка.Следующий();
	КоличествоЗаТекущийМесяц = Выборка.КоличествоОтсутствий;
	
	//За текущую неделю
	Запрос.УстановитьПараметр("ДатаНачала", НачалоНедели(ТекущаяДата));
	Запрос.УстановитьПараметр("ДатаОкончания", КонецНедели(ТекущаяДата));
	
	Выборка = Запрос.Выполнить().Выбрать();
	Выборка.Следующий();
	КоличествоЗаТекущуюНеделю = Выборка.КоличествоОтсутствий;
	
	//За текущий день
	Запрос.УстановитьПараметр("ДатаНачала", НачалоДня(ТекущаяДата));
	Запрос.УстановитьПараметр("ДатаОкончания", НачалоДня(ТекущаяДата));
	
	Выборка = Запрос.Выполнить().Выбрать();
	Выборка.Следующий();
	КоличествоЗаТекущийДень = Выборка.КоличествоОтсутствий;
	
	ЗначенияПоказателей = Новый Массив;
	
	ОтсутствияЗаТекущийМесяц = СтруктураПоказателя();
	ОтсутствияЗаТекущийМесяц.Заголовок = НСтр("ru = 'Месяц'");
	ОтсутствияЗаТекущийМесяц.ЦветЗаголовка = ЦветаВиджета.ЦветПодписи;
	ОтсутствияЗаТекущийМесяц.Значение = КоличествоЗаТекущийМесяц; 
	ОтсутствияЗаТекущийМесяц.Ссылка = "Отсутствия_ЗаТекущийМесяц";
	ОтсутствияЗаТекущийМесяц.ИмяПоказателя = "Отсутствия_ЗаТекущийМесяц";
	ЗначенияПоказателей.Добавить(ОтсутствияЗаТекущийМесяц);
	
	ОтсутствияЗаТекущуюНеделю = СтруктураПоказателя();
	ОтсутствияЗаТекущуюНеделю.Заголовок = НСтр("ru = 'Неделя'");
	ОтсутствияЗаТекущуюНеделю.ЦветЗаголовка = ЦветаВиджета.ЦветПодписи;
	ОтсутствияЗаТекущуюНеделю.Значение = КоличествоЗаТекущуюНеделю; 
	ОтсутствияЗаТекущуюНеделю.Ссылка = "Отсутствия_ЗаТекущуюНеделю";
	ОтсутствияЗаТекущуюНеделю.ИмяПоказателя = "Отсутствия_ЗаТекущуюНеделю";
	ЗначенияПоказателей.Добавить(ОтсутствияЗаТекущуюНеделю);
	
	ОтсутствияЗаТекущийДень = СтруктураПоказателя();
	ОтсутствияЗаТекущийДень.Заголовок = НСтр("ru = 'Сегодня'");
	ОтсутствияЗаТекущийДень.ЦветЗаголовка = ЦветаВиджета.ЦветПодписи;
	ОтсутствияЗаТекущийДень.Значение = КоличествоЗаТекущийДень; 
	ОтсутствияЗаТекущийДень.Ссылка = "Отсутствия_ЗаТекущийДень";
	ОтсутствияЗаТекущийДень.ИмяПоказателя = "Отсутствия_ЗаТекущийДень";
	ЗначенияПоказателей.Добавить(ОтсутствияЗаТекущийДень);

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

 

Вызов данной процедуры необходимо поместить в процедуру "ЗаполнитьВиджетыТекущихДел" общего модуля "ТекущиеДелаДокументооборотСервер":

 
 Добавление вызова процедуры добавления виджета

 

//Типовой код
.............
.............

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

 

4) Необходимо добавить обработку нажатия на элементы виджета в процедуре "ОбработатьНажатиеНаСсылку" общего модуля "ТекущиеДелаДокументооборотКлиент":

 
 Код процедуры обработки нажатия на ссылку

 

//Типовой код
.............
.............

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

 

5) Если данный виджет необходимо добавить всем пользователям, тогда необходимо доработать функцию "РасположениеВиджетовПоУмолчанию" модуля менеджера регистра "НастройкиТекущихДел". 

 

Результат работы нового виджета:

Данная доработка тестировалась в 1С документооборот версии 2.1.15.4.

Infostart Dashboards — дашборды и метрики в 1С

Решение «Инфоборды» позволяет собрать все ключевые показатели и метрики прямо на главном экране . Настраивайте панели с виджетами — выручка, долги, KPI, задачи, остатки и динамика продаж — всё в виде интерактивных дашбордов. Контролируйте эффективность компании в реальном времени без отчётов и сложных запросов.

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

документооборот собственный виджет отсутствия

См. также

Работа с интерфейсом Анализ учета Мониторинг 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"!

28800 руб.

27.03.2025    59911    34    29    

46

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

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

36000 руб.

28.08.2025    4146    1    2    

4

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

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

6000 руб.

14.01.2016    58668    20    25    

46

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

Обработка предназначена для создания и управления дашбордами (виджетами) в 1С.

5160 руб.

29.06.2020    23217    33    6    

52

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

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

5988 руб.

17.10.2025    1114    1    0    

1

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

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

20.08.2024    44581    mrXoxot    44    

138

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

Пример простого и симпатичного прогресс-бара в динамическом списке, без картинок, используя редактирование запроса.

27.05.2024    25274    smielka    38    

112

Инструментарий разработчика Работа с интерфейсом Программист 1С:Предприятие 8 1C:Бухгалтерия Абонемент ($m)

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

3 стартмани

10.04.2023    16676    179    acces969    31    

132
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. mvxyz 331 20.12.19 10:37 Сейчас в теме
Спасибо! Пригодится.
pro96inf; +1 Ответить
2. Тильчик 10.07.21 07:51 Сейчас в теме
Спасибо! Мучался сам, последнюю процедуру не нашел, теперь все ОК
3. GusevSI 22.05.23 07:59 Сейчас в теме
Добрый день!

Создал новый виджет, пользователи могут его подключать. А есть ли возможность принудительно включить новый виджет всем пользователям?
Для отправки сообщения требуется регистрация/авторизация