Выкладываю шаблон отчета на СКД для обычных и управляемых форм, который я использую для создания новых отчетов.
Обычную форму шаблона постарался сделать максимально похожей на типовой отчет. Но в отличии от типового, шаблон отчета работает в любых конфигурациях «сам по себе».
Весь функционал реализован как для обычных, так и для управляемых форм.
Также этот шаблон будет полезен начинающим разработчикам для примера реализации следующих ситуаций (как для обычных, так и для управляемых форм):
- Программное выполнение отчета на СКД.
- Программная установка отборов в СКД.
- Программная установка параметров в СКД.
- Программное изменение параметров вывода в СКД.
- Привязка своего макета оформления в отчет на СКД.
- Расшифровка ячейки отчета и получения значений группировки выбранной ячейки результата отчета.
- Обработка расшифровки в очете на СКД, в виде отдельного отчета со своей компоновкой данных.
- Удобное меню для выбора периода.
- Удобная функция сохранения в Excel.
- Установка параметров документа Excel при сохранении (границы, ориентация и пр.)
- Сохранение в Excel из WEB-Клиента
- …
Смотрите также: Шаблон обработки (обычные и управляемые формы)
А чем он лучше типового шаблона?
Неплохо!
Скрины в студию! На представленных иллюстрировано лишь пункт 7. Удобное меню для выбора периода. Хотелось бы больше …
(1) PrinzOfMunchen,
Старался его сделать очень похожим на типовой. А лучше тем, что не зависит от конфигурации и не требует дополнительных модулей, работая «сам по себе».
(3) DAnry,
А какие еще нужны скрины? Весь описанный функционал в коде.
хотел плюсануть, но как?
(5) mikl79,
Авторизируетесь на сайте и нажимаете кнопку в виде оранжевой звездочки чуть ниже таблички «Файлы». 🙂
Плюсану авансом, может пригодится )
Забрал, спасибо. Очень не люблю расписывать всякие интерфейсные плюшки. Почему-то достаются отчеты со сложными выборками данных. Поэтому готовые шаблоны забираю;)
Автору спасибо за проделаный труд. Обязательно скачаю как появятся деньги. отчет написать ето одно но зделать его юзабилика как говорят ето совсем другое. Поетому людям которые решились на ето вызывают у меня уважение. СПАСИБО та к держать
Tavalik, добрый день. Подскажите, пожалуйста, в Вашей разработке есть ли возможность задавать имена листам
(не название сохраняемого файла) сохраняемым в xls или xlsx ? Решается ли проблема «съедания» ведущих нолей в текстовых полях «Код» ? Спасибо.
(10) sergiobargio1,
Доброго времени суток.
К сожалению на данный момент нет возможности задавать имена, проблема пропадания ведущих нулей также не решена.
Сохранение в Excel вынесено в отдельную процедуру, пока только могу предложить Вам доработать ее самостоятельно.
Эта проблема решается, например, добавлением пользовательского поля X такого вида «‘» + [Код]. В итоге все значения будут иметь вид «‘0000000001», что при сохранении в Excel штатными методами даст нормальную текстовую ячейку со всеми нулями, символ апострофа же при обработках формулами и т.д. игнорируется.
Об этом уже писали на Инфостарте и это абсолютно штатная фича как Excel так и Open(Libre)Office.
Есть два вопросика:
1. нет дает открыть два отчет(внешних) разработанных используя шаблон
2. нажимаю сформировать отчет, слетает схема, обычная форма.
Огромное спасибо автору за труды, обязательно качну как только появится бабосы….
(15) Tangram,
Нет, работу с вариантами я не делал, т. к. для обычных форм на практике почти всегда используем механизм сохранения настроек типовых конфигураций. Если конфигурация нетиповая, то как мне кажется, проще допилить ее, добавив один регистр сведений и один общий модуль.
Отлично подходит для нетиповых конфигураций, спасибо. Работа с вариантами отчетов не реализована или я не увидел?
(13) Константин С.,
Скопируйте основную форму отчета, назначьте ее основой, а старую удалите.
Тогда новый отчет будет открываться с новым идентификатором формы.
Отличный шаблон, аккуратно сделан, порадовала панель с периодом! Попробую в работе и буду использовать для внешних отчетов, вместо текущего шаблона.
Спасибо за работу!
Есть предложения по развитию, все касаются управляемых форм:
1. Можно использовать механизм работы с длительными операциями, потому что сейчас, если формировать длительный отчет, программа зависает. К стати, при расшифровке отчета этот механизм работает, а при нажатии «Сформировать» — нет
2. При нажатии на кнопки выбора периода постоянно появляется сообщение «Использование модальных окон в данном режиме запрещено!», не критично, но отвлекает. К стати в выборе периода с.. по можно использовать стандартный диалог выбора периода (в виде календаря, который например в БП 3.0 в стандартных отчетах)
3. В отчет можно сразу добавить код для подключения его в качестве внешнего
предложение:
добавить Функция СведенияОВнешнейОбработке() Экспорт
для автоматической регистрации в типовых конфигурациях)))
В последней версии исправили обновление дат, это здорово, а вариант отчета не обновляется, если выбрать другой вариант.
Надо к событию формы ПриЗагрузкеВариантаНаСервере привязать код
Пожелание к оформлению публикации. Можно указывать номер текущей версии шаблона.)))
Замечательно, забираю. Спасибо автору
Добрый день. Подскажите, если отчет строится для остатков, то есть нужна одна конкретная дата, а не диапозон, то как ему это задать?
Автор если планируется развитие даной обработки можно ли добавить. Кнопку для отправки отчета на електроную почту.
Спасибо. Красиво и аккуратно. Небольшой косячок: установка видимости заголовка отчета через УстановитьВидимостьЗаголовкаОтчета() глючит. Например, с отчетом в виде таблицы с двумя группировками в строках затираются заголовки столбцов:) Не страшно, но я вот не сразу понял, что происходит, думал всё, допрограммировался)
Посмотрел, действительно работает без всяких модулей, только при каждом закрытии требует сохранения варианта отчета. Надоедает страшно. Теперь голову ломаю, как это убрать. Сообщение «Вариант «Имя варианта» был изменен. Сохранить измененный вариант?» обыскался, в обработке такого сообщения нет и события при закрытии тоже, откуда ноги не понятно.
Поборол, убрав свойство модальности варианта отчета
&НаКлиенте
Процедура ПередЗакрытием(Отказ, СтандартнаяОбработка)
Если ЭтаФорма.ВариантМодифицирован=Истина тогда
ЭтаФорма.ВариантМодифицирован = ложь;
КонецЕсли;
КонецПроцедуры
Очень хорошо!
Еще можно добавить автосуммирование по выделенным ячейкам.
Спасибо!
А объясните кто-нибудь, пожалуйста, что за вопрос, за решение которого дается вознаграждение, я что-то запутался
Спасибо за хороший шаблон. Неоднократно успешно им пользовалась. Безумно нравится что он реально самостоятельный и нет ограничения в программе. Мелочи типа установки видимости заголовка не в счет (легко подпиливаются).
(18) BlackStar, Чтобы не появлялось сообщение «Использование модальных окон в данном режиме запрещено!» замените ВыбратьИзМеню на ПоказатьВыборИзМеню:
Оповещение = Новый ОписаниеОповещения(«ПослеВыбораИзМеню», ЭтотОбъект);
ПоказатьВыборИзМеню(Оповещение, СписокИнтервалов);
&НаКлиенте
Процедура ПослеВыбораИзМеню(Интервал, Параметры = Неопределено) Экспорт
Если Интервал <> Неопределено Тогда
Отчет.Период = Интервал.Значение;
Элементы.ПериодУстановка.Заголовок = Отчет.Период;
ПериодУстановка(Неопределено);
КонецЕсли;
КонецПроцедуры
Проблема с периодом обнаружилась. Делаем отчёт для УТ 11.0. При загрузке отчёт показывает один период, а формируется совершенно за другой. Как будто при формировании берётся период из какого-то кэша от прошлого запуска отчёта. Тоже самое происходит при выборе вариант отчёта. Пробовал ПередЗагрузкойВариантаНаСервере очищать период, но всё равно формируется он по прошлому заданному периоду. Никак не могу найти ошибку. А без этого отчёт не удобен в использовании.
Нашёл работающий вариант исправления. В процедуру СформироватьОтчет добавил обновление представления даты:
Процедура СформироватьОтчет(Команда)
//добавлено для работы с выбором вариант отчета
Элементы.ПредставлениеДаты.Заголовок = ОбновитьПредставлениеДатыНаСервере();
//добавлено для работы с выбором вариант отчета
//Получаем схему из макета
СформироватьОтчетНаСервере();
//Состояние отчета
Элементы.Результат.ОтображениеСостояния.Видимость = Ложь;
Элементы.Результат.ОтображениеСостояния.ДополнительныйРежимОтображения = ДополнительныйРежимОтображения.НеИспользовать;
КонецПроцедуры
Норм, чо)
Крутой шаблон — использовал раньше и другие — этот лучше и навороченный по функционалу БСП
+1
С удовольствием использую.
Но есть два пожелания:
1. Желательно добавить значение Истина четвертым параметром в ПроцессорКомпоновкиДанных.Инициализировать(…), иначе нельзя использовать функции общих модулей в вычисляемых полях
2. ОткрытьЗначение(…) в форме отчета и расшифровки в веб-клиенте не работает, надо менять на ПоказатьЗначение(…)
(35)
Применял при создании:
Отчет по проводкам (плоский) для УПП 1.3, КА 1.1
Что-то у меня в УТ 11 (11.2.3.189) ошибка при открытии настроек выходит …
{ОбщаяФорма.ФормаНастроекОтчета.Форма(27)}: Не передан служебный параметр «НастройкиОтчета».
ВызватьИсключение НСтр(«ru = ‘Не передан служебный параметр «»НастройкиОтчета»».'»);
(38)
{ОбщаяФорма.ФормаНастроекОтчета.Форма(27)}: Не передан служебный параметр «НастройкиОтчета».
ВызватьИсключение НСтр(«ru = ‘Не передан служебный параметр «»НастройкиОтчета»».'»);
(32)
Когда сделаете?
(38)
в УТ 11 по умолчанию используется форма настроек отчетов из БСП. Если нужна именно эта форма, то рекомендую и основную форму отчета брать из БСП.
Добавил в отчет управляемую форму настроек отчета.
(39)
Добавлена форма настроек в отчет.
(32)
Здравствуйте. К сожалению (или к счастью) не могу повторить описанную вами ошибку.
Хороший шаблон. Рекомендую доработать:
https://its.1c.ru/db/v8std#content:2149184104:hdoc
— добавить программный интерфейс регистрации для доп. отчетов и обработок БСП, номер версии вести соотв. там
— заголовок формы возвращать из экспортного метода модуля объекта
— структуры модулей оформить по ИТС
— в обычной форме отказаться от «СохранитьЗначение» «ВосстановитьЗначение», использовать штатный функционал управления настройками. Кстати, флаг в обычной форме включен, но значения для сохранения не выбраны
— формы переименовать) Я забывал пару раз удалять форму, из-за чего получал «двойников»: если есть два отчета, реализованные на одном и том же шаблоне и с одной и той-же формой, то если открывать отчет №2 при открытом отчете№1 — открытия не произойдет, а просто активируется отчет №1. Поэтому у себя в шаблоне форму именую так: «ФормаОтчета_НЕ_ИСПОЛЬЗОВАТЬ_СКОПИРОВАТЬ_ЭТУ_УДАЛИТЬ».
У меня сейчас так (в конфе устаревшая версия БСП):
Показать
Спасибо автору!
Здравствуйте,скачал ваш шаблон,спасибо он прекрасен!))но есть необходимость в кнопке переключения макета,если вас не затруднит,не могли бы вы скинуть эту процедуру!очень нужно…
(45)
Здравствуйте. Честно говоря, шаблон был написан для УПП, а я с ней уже давно не работал. Не совсем понял, о какой кнопке идет речь? Какой макет необходимо менять?
(46)Вот у меня есть два макета СКД с разными наборами данных!т.е. нужно что бы можно было переходить на другой макет СКД!что то типа вот этого сейчас покажу на скринах ,но тут ошибки в написании модуля..но для образца пойдет!
(47)
Отчет формируется программно, т. е. в модуле реализована процедура «ПриКомпоновкеРезультата», где и происходит вывод отчета в табличный документ. Добавьте на форму поле с нужным списком выбора, а при компоновке результата получаете необходимый макет по значению этого поля.