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