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

30.01.24

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

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

Скачать исходный код

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

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

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

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

&НаКлиенте
Процедура ПриИзмененииКоличества()
    
    ИмяКолонкиКоличества = Элементы["МатрицаПланов"].ТекущийЭлемент.Имя;  
    КолВоНовое = Элементы["МатрицаПланов"].ТекущиеДанные[ИмяКолонкиКоличества];
    Если ВернутьКоличество Тогда
        Элементы["МатрицаПланов"].ТекущиеДанные[ИмяКолонкиКоличества] = КолВоДоРедактирования; 
    Иначе
        //------Точно рабочий вариант
        КолвоДо = КолВоДоРедактирования; //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С v8.3 Конфигурации 1cv8 Платные (руб)

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

2400 руб.

29.06.2020    17190    23    4    

37

Новогоднее оформление для 1С

Работа с интерфейсом Платформа 1С v8.3 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Зарплата и Управление Персоналом 3.x 1С:Управление нашей фирмой 3.0 Бесплатно (free)

Добавьте новогоднего настроения! Расширение создает декорацию в виде гирлянды на некоторых формах объектов.

27.12.2023    11676    776    elcoan    47    

108

Конструктор HTML, CSS и javascript

Инструментарий разработчика Работа с интерфейсом Программист Платформа 1С v8.3 Конфигурации 1cv8 Абонемент ($m)

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

2 стартмани

10.04.2023    10210    157    acces969    31    

120

Модель состояния для MVC

Работа с интерфейсом Программист Платформа 1С v8.3 Конфигурации 1cv8 Абонемент ($m)

"MVC плохо применима в 1С" - познакомьтесь с моделью состояния и, возможно, ваше мнение поменяется! Представленное решение является эволюционным развитием идеи реализации MVC для 1С. В новой версии добавлены DSL для описания модели состояния, а также параметризация свойств параметров и элементов формы.

1 стартмани

05.07.2022    4207    kalyaka    4    

31

Условное оформление элементов форм в пользовательском режиме 1С (управление видимостью и доступностью элементов форм)

Работа с интерфейсом Платформа 1С v8.3 Платные (руб)

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

6000 руб.

18.01.2022    9109    1    2    

6

Программный интерфейс для доработки форм

Работа с интерфейсом Программист Платформа 1С v8.3 Конфигурации 1cv8 Бесплатно (free)

Реализовал простой способ программного создания новых элементов, команд и реквизитов на форме.

25.11.2021    10012    AtamanovYS    19    

141
Оставьте свое сообщение