Визуализация деревьев с функциональностью Drag&Drop

21.03.22

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

В статье приведен пример реализации визуализации деревьев с функциональностью Drag&Drop.

Скачать файл

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

Наименование По подписке [?] Купить один файл
Визуализация деревьев с функциональностью Drag&Drop:
.epf 48,35Kb
15
15 Скачать (1 SM) Купить за 1 850 руб.

Исходная задача

Согласно ITIL 4, CMDB — Configuration Management Data Base — переводится как «база данных управления конфигурацией». Это глобальное хранилище, которое включает все элементы ИТ-инфраструктуры организации и логические связи между ними. CMDB охватывает как аппаратные и программные компоненты (серверы, ПК и т.д.), так и конфигурации. В результате складывается комплексная картина всего ИТ-ландшафта.

Необходимо реализовать функциональнось визуализации и интерактивного изменения дерева ИТ-ландшафта.

 

Какие инструменты были опробованы?

1. Graphviz

2. jOrgChart

GraphVis очень крутой инструмент, но в данной ситуации он не подошёл. Единственная причина - он дает статическую картинку (нет возможности перемещать элементы - Drag&Drop)

jOrgChart - это плагин javascript, позволяющий визуализировать деревья в HTML и поддерживающий функциоанльность Drag&Drop.

За основу была взята обработка Сергея Белькина

Что было добавлено/изменено:

1. Добавлен механизм анализа внесенных изменений (исходное дерево, текущее дерево);

2. Оптимизированы рекурсивные алгоритмы обработки деревьев;

3. Добавлен механиз хранения деревьев в виде массива предков. В теории, любой граф (дерево в частности) можно хранить тремя способами: список смежности, список ребер, матрица смежности. Плюс деревья можно хранить/обрабатывать в виде массива предков - что ускоряет работу алгоритма.

 

Общий алгоритм работы

 

Особенности реализации

1. Каждому элементу назначается ID - уникальный порядковый идентификатор, по которому будет проводиться обратное восстановление дерева объектов. При этом ID будет равен индексу массива предков, соответствующего дерева. На визуализации для каждого элемента будет добавляться строка "#IDxx" - это в принципе можно избежать - например, хранить ID скрытом теге <p> html.

2. Анализ изменений через массив. Текущее и исходное деревья хранятся не в типе данных ДеревоЗначений, а в массиве. Сделано для ускорения алгоритма.

Тестировал на платформе 1С:Предприятие 8.3 релиз 8.3.20.1674

 

Видео демонстрация функциональности Drag&Drop и анализа измененных объектов:

 

 

См. также

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

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

6000 руб.

16.01.2015    63361    44    59    

82

Работа с интерфейсом Программист Платформа 1С v8.3 Конфигурации 1cv8 1С:ERP Управление предприятием 2 Платные (руб)

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

2400 руб.

29.06.2020    19180    26    6    

41

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

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

1500 руб.

06.10.2020    10495    7    7    

11

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

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

20.08.2024    18788    mrXoxot    44    

126

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

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

27.05.2024    8707    smielka    37    

102

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

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

27.12.2023    16245    1085    elcoan    50    

118

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

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

2 стартмани

10.04.2023    12212    165    acces969    31    

124
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. cmax 107 25.04.22 18:17 Сейчас в теме
Если в дереве - несколько первых строк, можно ли вывести несколько деревьев друг под другом?
если да - то как? я не смог понять.
Сейчас выводится только иерархия по первой строке.
3. farukshin 120 27.04.22 10:34 Сейчас в теме
(1)

Нельзя, т.к. это будет несвязный неориентированный граф (точнее лес), а не дерево.

Можно подвесить их к одной вершине, например "Все конфигурационные единицы". Преимущество такого решения - комплектующие можно будет не просто перемещать внутри одной КЕ, но и "выводить из эксплуатации" (вешая на эту вершину).
2. cmax 107 25.04.22 18:30 Сейчас в теме
И еще вопрос - где меняется цвет? меняю значения в функции ЗаполнитьЗначенияПоУмолчанию - ЦветПлашек, ширина, высота и другие - ничего не меняется абсолютно в отображении..
4. farukshin 120 27.04.22 10:36 Сейчас в теме
(2)

Все верно, меняется изменением значения реквизитов ЦветПлашек и т.п. При изменении цвета у вас css файлы меняются, но встроенный в 1С браузер их кэширует (на время сеанса 1С в каталоге временных файлов). Откройте новый сеанс - цвета поменяются.

Если вам кэширование не нужно - можно обойти разными способами, например:
1) в функции СозданыЗависимостиJS_CSS() в каталоге временных файлов создавать уникальный каталог, в котором хранить все файлы;
2) получать custom.css с рандомным параметром, в самом HTML заменить строку <link rel="stylesheet" href="css/custom.css?"/> на <link rel="stylesheet" href="css/custom.css?116"/>, где 116 - рандомное число. При этом custom.css будет принудительно считываться при каждом запросе.
5. cmax 107 27.04.22 10:38 Сейчас в теме
(4) Спасибо за ответ! буду пробовать.
6. cmax 107 28.04.22 16:12 Сейчас в теме
(4) Получилось с цветами и размерами. Все отлично.
Вопрос еще возник, возможно ли сделать перевертыш - перевернуть дерево вниз корнем?
Есть понимание как это сделать, если вообще возможно?
Оставьте свое сообщение