Добавление собственного виджета в 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, задачи, остатки и динамика продаж — всё в виде интерактивных дашбордов. Контролируйте эффективность компании в реальном времени без отчётов и сложных запросов.

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

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

Вы можете заказать платную адаптацию этой статьи под ваши задачи на «Бирже заказов».

  • 0% комиссии — оплата напрямую исполнителю;
  • Исполнители любого масштаба — от отдельных специалистов до команд под проект;
  • Прямой обмен контактами между заказчиком и исполнителем;
  • Безопасная сделка — при необходимости;
  • Рейтинги, кейсы и прозрачная система откликов.

См. также

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

В публикации рассмотрены все возможные (ну или почти все) варианты программного открытия форм в управляемом приложении. Появление публикации связано с тем, что справка 1С и желтые книжки очень немногословны на эту тему. Часто простые задачи (например, создание элемента справочника на основании) вызывают трудности даже у очень опытных разработчиков 1С v 8.1, которые мало работали с управляемым приложением.

10.11.2013    663304    kser87    184    

912

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

Полноценная обработка, содержащая оффлайн версию JavaScript графиков AmCharts версии 3.2.0. С обработкой нажатия мыши. Все виды графиков: Column, Bar, Line, Area, Step, Smoothed line, Candlestick, Pie/Donut, Radar/Polar, XY/Scatter/Bubble, Bullet, Funnel/Pyramid.

3 стартмани

01.11.2013    48302    266    pfihr    43    

130

Загрузка и выгрузка в Excel Работа с интерфейсом Программист 1С:Предприятие 8 Абонемент ($m)

Что делать, если средствами 1С не получается нарисовать диаграмму, которую хочет Заказчик? Выход есть!

1 стартмани

10.10.2013    28448    146    Сисой    1    

12

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

Тёмные цветовые схемы кода. То, что было доступно всем передовым средствам разработки, теперь доступно и на 1С. 13.12.17 UPD: Теперь работает с платформой 8.3

3 стартмани

07.10.2013    57679    204    Chernov_Dmitriy    83    

59

Работа с интерфейсом Программист Бесплатно (free)

Казалось бы, все сделано по уму: и ТЗ адекватное, и программа написана в соответствии. А глаз не радует... Для тех кому знакома ситуация, кому важна гармония во всем, посвящается:

17.09.2013    26676    Evgen.Ponomarenko    13    

36

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

Набор инструментов, позволяющий запустить любую Вашу процедуру &НаСервере в фоновом режиме и отображать пользователю состояние её выполнения.

100 руб.

16.09.2013    44923    80    30    

55

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

Обработка устанавливает константу на будущий год, для всех пользователей...

1 стартмани

04.09.2013    17467    41    GoodWinSpr    8    

5

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

Видел много решений открытия "внешнего проигрывателя" из Windows, в самой 1С на форме не видел. Может кому пригодиться достаточно простой способ реализации.

1 стартмани

29.08.2013    20135    110    demart-omsk    7    

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

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