Подсчет итогов в колонках дерева значений на управляемой форме

30.01.24

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

Ещё один из вариантов пересчета итогов в колонках дерева значений, выведенного на форму, при интерактивном изменении пользователем значений в дереве.

Бесплатные

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Узнавайте о новых бесплатных решениях в нашей телеграм-группе Инфостарт БЕСПЛАТНО

Наименование Скачано Бесплатно
Подсчет итогов в колонках дерева значений на управляемой форме:
.epf 11,40Kb
103 Скачать бесплатно

Понадобилось как-то дать возможность менеджерам компании видеть свои планы продаж в одной таблице. Более того, не просто видеть, а иметь возможность поменять значения для последующего сохранения в базе данных (в документах, регистрах и проч.). При этом одним из пожеланий было видеть данные в виде дерева значений для удобства понимания ситуации и возможностью сворачивать группировки, чтобы не мешали работать с нужными данными.

Пересмотрев несколько вариантов получения итогов в результирующих строках по колонкам, наиболее удобным для себя выбрал вариант пересчета с помощью рекурсивной процедуры. Удобство данного варианта для меня заключалось в том, что он позволял реализовать весь алгоритм на клиенте и тем самым не прибегая к таким функциям, как РеквизитФормыВЗначение и ЗначениеВРеквизитФормы.

Для реализации потребовалось создать помимо дерева значений несколько реквизитов формы и заполнять их в подключаемых к дереву процедурах при начале изменении, активизации и изменении конкретной ячейки.

&НаКлиенте
Процедура ПриИзмененииКоличества()
    
    ИмяКолонкиКоличества = Элементы["МатрицаПланов"].ТекущийЭлемент.Имя;  
    КолВоНовое = Элементы["МатрицаПланов"].ТекущиеДанные[ИмяКолонкиКоличества];
    Если ВернутьКоличество Тогда
        Элементы["МатрицаПланов"].ТекущиеДанные[ИмяКолонкиКоличества] = КолВоДоРедактирования; 
    Иначе
        //------Точно рабочий вариант
        КолвоДо = КолВоДоРедактирования; //0;
        ОбновитьКоличество(ЭтаФорма.МатрицаПланов.НайтиПоИдентификатору(Элементы["МатрицаПланов"].ТекущаяСтрока), КолвоДо, КолВоНовое, ИмяКолонкиКоличества);     
        //------Альтернативный вариант, но надо доработать рекурсивное заполнение
        //ПересчитатьДерево(ИмяКолонкиКоличества);
        //------Да и после обновление дерево окажется закрытым см.процедуру
    КонецЕсли;
    
КонецПроцедуры   

&НаКлиенте
Процедура ПриАктивацииКоличества() 
    
    ИмяКолонкиКоличества = Элементы["МатрицаПланов"].ТекущийЭлемент.Имя;  
    
КонецПроцедуры

&НаКлиенте
Процедура ПриНачалеРедактированияКоличества() 
    
    ИмяКолонкиКоличества = Элементы["МатрицаПланов"].ТекущийЭлемент.Имя; 
    КолВоДоРедактирования = Элементы["МатрицаПланов"].ТекущиеДанные[ИмяКолонкиКоличества];
    Если ЭтаФорма.МатрицаПланов.НайтиПоИдентификатору(Элементы["МатрицаПланов"].ТекущаяСтрока).ПолучитьЭлементы().Количество() <> 0 Тогда
        ВернутьКоличество = Истина;
    Иначе
        ВернутьКоличество = Ложь;
    КонецЕсли;
    
КонецПроцедуры


Далее при интерактивном изменении значения в ячейке пользователем запускается рекурсивная процедура.

&НаКлиенте
Процедура ОбновитьКоличество(ТекущаяСтрокаДерева, КолДо=0, КолПосле, ИмяКолонкиКоличества)
    
    РодительСтроки = ТекущаяСтрокаДерева.ПолучитьРодителя();
    Если РодительСтроки <> Неопределено Тогда
        РодительСтроки[ИмяКолонкиКоличества] = ?(РодительСтроки[ИмяКолонкиКоличества]=Неопределено, 0, РодительСтроки[ИмяКолонкиКоличества]) + КолПосле - КолДо; 
        ОбновитьКоличество(РодительСтроки, КолДо, КолПосле, ИмяКолонкиКоличества);
    КонецЕсли;
    
КонецПроцедуры 

В прилагаемой обработке кроме указанных выше процедур существуют также процедуры по программному созданию дерева значений исходя из данных, заполненных в трёх таблицах и в реквизите "Период построения". По таблицам создаётся трёхуровневое дерево значений с колонками, представляющими месяцы из указанного периода.

Обработка тестировалась в Конфигурации 1С:ERP Управление предприятием 2.5.12.208 и 1С:Управление производственным предприятием на Платформе 1С v8.3.23.1865, но подойдут и другие конфигурации на управляемых формах начиная с платформы 1С v8.3.14.

Проверено на следующих конфигурациях и релизах:

  • 1С:ERP Управление предприятием 2, релизы 2.5.14.82, 2.5.14.74

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

Дерево значений Итог

См. также

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

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

31720 руб.

27.03.2025    78912    52    40    

63

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

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

36600 руб.

28.08.2025    7354    2    2    

6

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

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

6100 руб.

14.01.2016    60039    22    25    

47

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

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

6088 руб.

17.10.2025    1884    3    0    

2

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

Универсальный редактор картинок 1С предназначен для обработки изображений в режиме «Предприятие», с возможностью рисовать на них. Поддерживается работа как в обычных формах (толстый клиент) так и на управляемых формах (тонкий клиент). Обработка позволяет редактировать как картинки, хранимые в базе, так и графические файлы с диска на файловой системе. Помимо базовых функций (изменение размеров, преобразование формата, обрезание картинки, повороты и т.п.) – редактор имеет богатый набор инструментов для рисования. Доступна функция вставки изображения из буфера обмена. Объект может быть использован: на стороне клиента, на стороне сервера, из внешнего соединения. Обработка будет особенно полезна тем, кто вносит картинки в базу (изображения номенклатуры, фотографии физических лиц и т.п.). Функционал реализуется с использованием JavaScript и бесплатного ПО ImageMagick (без использования внешних компонент).

6100 руб.

16.01.2015    68068    46    60    

85

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

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

20.08.2024    48698    mrXoxot    44    

139

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

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

27.05.2024    26259    smielka    39    

116
Для отправки сообщения требуется регистрация/авторизация