paint-brush
Mis 13 mejores bibliotecas de diagramas de JavaScriptpor@eugene_p
63,801 lecturas
63,801 lecturas

Mis 13 mejores bibliotecas de diagramas de JavaScript

por Eugene_P12m2020/05/21
Read on Terminal Reader
Read this story w/o Javascript

Demasiado Largo; Para Leer

JavaScript es la tecnología más universal y fácil de usar para la visualización de datos. Actualmente, hay una gran cantidad de bibliotecas de diagramas JS disponibles en el mercado de software y cada una de ellas tiene sus pros y sus contras. En este artículo, intentaré ayudar a los desarrolladores que todavía están en la búsqueda de una biblioteca de diagramas adecuada para sus proyectos revisando 13 soluciones notables (presentadas en orden alfabético) DHTMLX Diagram es una práctica biblioteca de diagramas de JavaScript que le permite agregar diagramas bien estructurados. y diagramas interactivos y organigramas en su aplicación web.

Companies Mentioned

Mention Thumbnail
Mention Thumbnail

Coin Mentioned

Mention Thumbnail
featured image - Mis 13 mejores bibliotecas de diagramas de JavaScript
Eugene_P HackerNoon profile picture

Hoy en día, la cantidad de datos crece exponencialmente, y cuanta más información vemos, más minucioso y lento se vuelve analizarlo. Con la llegada de los grandes datos, el mundo de los negocios se enfrentó a la necesidad de cambiar de las hojas de cálculo tradicionales de Excel a formas más efectivas de visualización de datos: diagramas, gráficos, tableros y mapas coloridos e interactivos. Gracias a las modernas herramientas de visualización de datos, las personas pueden dedicar menos tiempo y esfuerzo a comprender conceptos difíciles o identificar nuevos patrones, lo que contribuye significativamente a una toma de decisiones más eficaz.

En la mayoría de los casos, los desarrolladores recurren al uso de JavaScript, ya que es la tecnología más universal y fácil de usar para la visualización de datos. Actualmente, hay una gran cantidad de bibliotecas de diagramas JS disponibles en el mercado de software y cada una de ellas tiene sus pros y sus contras. En este artículo, intentaré ayudar a los desarrolladores que todavía están en busca de una biblioteca de diagramas adecuada para sus proyectos al revisar 13 soluciones notables (presentadas en orden alfabético).

1) Diagrama de primitivas básicas

Basic Primitives Diagram es una biblioteca de JavaScript que proporciona diferentes componentes de diagramación que se utilizan para la visualización y el análisis de dependencias. Basic Primitives garantiza la visualización adecuada de diagramas complejos dentro de un solo espacio de pantalla sin ningún impacto negativo en la usabilidad del diagrama. La función de diseño automático ofrece muchas capacidades funcionales para la descripción general, la edición y la navegación a través de los diagramas. Cuando se introducen cambios en el diagrama, se utilizan elementos API especiales (anotaciones) para mostrar el proceso de cambio del diagrama de un estado a otro.

Escrita en JS puro sin dependencia de bibliotecas de terceros, esta biblioteca admite navegadores modernos y móviles, así como la representación de gráficos en los modos VML, SVG y Canvas. Una de las características más destacables de esta librería es que independientemente de la licencia que se esté utilizando (gratuita o comercial), se puede descargar el código fuente e introducir cualquier tipo de cambios en él.

Gracias a una API completa, los desarrolladores pueden agregar, cambiar o eliminar cualquier elemento del diagrama o sus propiedades, y la biblioteca representará solo los elementos modificados a través de la API, proporcionando así una representación rápida y un alto rendimiento.

Tipos de diagramas admitidos: organigrama, árbol genealógico y gráfico de herencia, gráfico jerárquico de múltiples padres, visualización de dependencias, diagrama PERT, visualización de gráfico acíclico dirigido (DAG), diagrama de propiedad empresarial

Integración con frameworks JS: AngularJS, jQuery, ReactJS

Disponibilidad de editores de diagramas: editor de organigramas

Formatos de exportación de diagramas: no encontrado

Licencia y precio: Licencia no comercial (gratuita) 3.0; licencias comerciales de 385$ a 2,145$

2) Diagrama DHTMLX

DHTMLX Diagram es una práctica biblioteca de creación de diagramas de JavaScript que le permite agregar diagramas y organigramas bien estructurados e interactivos a su aplicación web. Gracias a su peso ligero, la biblioteca garantiza una renderización rápida y un alto rendimiento. El componente Diagrama DHTMLX permite crear diferentes tipos de diagramas, incluidos diagramas mixtos (diagrama + organigrama) con la ayuda de un conjunto predefinido de formas y conectores, y formas personalizadas. Todas las formas se pueden complementar con datos de texto, iconos e imágenes. Las funciones de zoom y desplazamiento aseguran un trabajo más conveniente y efectivo con diagramas grandes.

Curiosamente, no necesitará mucho tiempo para construir incluso el diagrama más complejo con una gran cantidad de formas, ya que esta biblioteca proporciona un algoritmo de diseño automático avanzado. Esta poderosa función ayuda a convertir formas colocadas caóticamente en un diagrama bien estructurado con solo unos pocos clics.

Esta biblioteca es compatible con cualquier tecnología del lado del servidor y es compatible con todos los navegadores populares. Pero lo más notable de DHTMLX Diagram es la disponibilidad de dos editores en vivo (uno para organigramas y otro para otros tipos de diagramas). Estos editores le permiten enriquecer diagramas estándar con formas personalizadas y cambiar su apariencia sobre la marcha utilizando paneles laterales altamente personalizables. La posibilidad de realizar acciones estándar en varias formas (seleccionar, mover, copiar, etc.) al mismo tiempo y aplicar el algoritmo de diseño inteligente ayuda a crear diagramas de cualquier escala mucho más rápido.

Tipos de diagramas admitidos: diagrama de Venn, organigrama, diagrama de clases UML, diagrama de red, diagrama de flujo, diagrama de actividades, árbol de decisión vertical y horizontal, diagrama de bloques, diagrama de ciclo de vida

Integración con marcos JS : Angular, React, Vue. js

Disponibilidad de editores de diagramas: editores de organigramas y diagramas en vivo

Formatos de exportación de diagramas: PDF, PNG, JSON

Licencia y precio: licencias comerciales desde 599$ hasta 2.899$

3) GoJS

GoJS es una biblioteca de JavaScript multifuncional diseñada para crear diagramas y gráficos interactivos en plataformas y navegadores web modernos. Gracias a una variedad de plantillas y diseños personalizables implementados en GoJS, los desarrolladores pueden crear fácilmente diagramas JS de nodos, enlaces y grupos complejos.

GoJS ofrece muchas funciones útiles (arrastrar y soltar, edición en el lugar, deshacer/rehacer, diseños automáticos, vistas generales de diagramas, etc.) para garantizar una experiencia de usuario e interactividad mejoradas. La biblioteca es conocida por su flexibilidad, ya que la variedad de características y propiedades integradas simplifica significativamente los procesos de personalización de los componentes del diagrama.

Cabe señalar que GoJS es extremadamente rápido y aprovecha al máximo HTML Canvas para admitir la creación de diagramas de alto rendimiento. Gracias a la arquitectura familiar de modelo/vista y una amplia gama de muestras interactivas, es fácil para los desarrolladores comenzar con diferentes tipos de diagramas. La documentación detallada ayuda a los desarrolladores a comenzar a usar esta poderosa biblioteca en poco tiempo.

Tipos de diagramas: diagrama de flujo, diagrama de estado, diagrama de sankey, diagrama de genograma, organigrama, puerto dinámico, diagrama de proceso industrial, diagrama de agrupación dinámica, mapa mental, diagrama UML

Integración con frameworks JS: Vue.js Angular, React, Electron

Disponibilidad de editores de diagramas: no encontrado

Formatos de exportación de diagramas: SVG y formatos de imagen

Licencia y precio: licencia gratuita (para fines académicos y educativos); licencias comerciales de 3.495$ a 9.950$


4) Organigrama de Google

Google Charts es una herramienta simple y popular utilizada para la visualización de datos en aplicaciones web. Además de una amplia gama de gráficos estándar, esta biblioteca también permite crear organigramas ordenados para representaciones vívidas de estructuras y jerarquías organizacionales. Dichos gráficos ayudan a las empresas a aclarar la estructura de informes, administrar la carga de trabajo de manera más eficiente y optimizar las actividades de planificación. Hay una rica galería de gráficos para elegir.

Dado que todos los organigramas de Google son completamente configurables e interactivos, puede crear fácilmente apariencias de diagramas exclusivas que se ajusten perfectamente a su aplicación. Es posible personalizar fácilmente los gráficos a través de CSS. Gracias al uso de HTML5/SVG, estos gráficos son compatibles con todos los navegadores y plataformas modernos sin necesidad de aplicar complementos adicionales.

Los organigramas, así como otros tipos de gráficos de Google, vienen con manuales y ejemplos vívidos. Cada manual incluye código para las funciones asociadas con un gráfico específico y listas de API. Los organigramas de Google son gratuitos, pero no puedes usar los componentes de Google JS en un servidor local, por lo que no es la mejor opción si trabajas con datos confidenciales. Además, también hay soporte limitado (solo guías y foro).

Tipos de diagramas: organigrama

Integración con marcos JS: no encontrado

Disponibilidad de editores de diagramas: no encontrado

Formatos de exportación de diagramas: no encontrado

Licencia y precio: Licencia Apache 2.0 (gratis)

5) Kit de herramientas JSPlumb

El kit de herramientas jsPlumb es una solución potente y fácil de usar para crear aplicaciones basadas en conectividad de JavaScript. Utiliza SVG y es compatible con todos los navegadores desde IE9 y versiones posteriores. jsPlumb Toolkit es un contenedor de la biblioteca jsPlumb de código abierto que ofrece algunas funcionalidades esenciales necesarias para crear un diagrama de acuerdo con sus gustos: vinculación de datos, widget de minimapa, diseños automáticos, panorámica/zoom, operaciones gráficas, carga/guardado de datos, deshacer/ acciones de rehacer, etc. Además, existe un sólido mecanismo declarativo para configurar la apariencia y el comportamiento de diferentes partes de la interfaz de usuario.

La biblioteca también proporciona una integración completa con dispositivos móviles. Con numerosas funciones de interfaz de usuario implementadas, Toolkit ofrece una forma efectiva de crear aplicaciones con conectividad visual en su núcleo. La disponibilidad de demostraciones y la documentación le permite obtener una mejor comprensión de su funcionalidad.

Tipos de diagramas admitidos: organigrama, diagrama de flujo, diseño circular, diagramas de flujo de proceso, diagrama de secuencia

Integración con frameworks JS: Angular, React, Vue

Disponibilidad de editores de diagramas: no encontrado

Formatos de exportación de diagramas: no encontrado

Licencia y precio: licencias comerciales desde 3.500$ hasta 8.500$

6) interfaz de usuario de Kendo

Kendo UI es un conjunto probado de herramientas de front-end desarrollado por el equipo de Progress que viene con una variedad de widgets útiles basados en jQuery, incluido el componente de diagramación, para crear aplicaciones web ricas en datos. Esta solución aprovecha al máximo las tecnologías HTML5 y CSS3 al tiempo que admite versiones modernas y bastante antiguas de navegadores. En las aplicaciones creadas con la suite de interfaz de usuario de Kendo, puede implementar el enlace de datos, el acceso a plantillas, la animación, la opción de arrastrar y soltar y mucho más.

El componente de diagramación entra en juego cuando es necesario enriquecer el diseño de la aplicación con diagramas de flujo interactivos, organizacionales, de red o cualquier interfaz de diagramación. Grandes cantidades de información se pueden presentar vívidamente en tipos de diagramas similares a los de Visio. El control de creación de diagramas es compatible con los diseños de diagramas más populares. También es posible aplicar el zoom dentro del espacio restringido para garantizar una fácil navegación entre las vistas de alto nivel.

El widget ofrece la funcionalidad de edición que le permite agregar herramientas y formas a su diagrama y utilizar sus opciones de diseño. La variedad de máscaras integradas permite a los desarrolladores ofrecer a los usuarios finales interfaces de usuario nítidas y un rendimiento rápido en poco tiempo, al mismo tiempo que utilizan menos recursos de diseño.

Tipos de diagramas admitidos: diagrama de flujo, organigrama, diagrama de red

Integración con frameworks JS: jQuery, Angular, React, Vue

Disponibilidad de editores de diagramas: demostración de edición

Formatos de exportación de diagramas: PDF, PNG, SVG

Licencia y precio: incluido en la biblioteca de interfaz de usuario de Kendo, licencias comerciales desde 999 $ hasta 2199 $ por desarrollador

7) mxGráfico

mxGraph es una biblioteca de creación de diagramas JS del lado del cliente que utiliza SVG y HTML para la visualización y ofrece todas las funcionalidades comunes necesarias para dibujar e interactuar con diagramas, así como para la integración de su lógica empresarial.

Desarrollado por JGraph Ltd en 2005, mxGraph se utilizó con éxito como una solución de software comercial hasta 2016, cuando dio paso a nuevas tecnologías frontend y la empresa hizo que el código fuente estuviera disponible gratuitamente en GitHub. Sin embargo, mxGraph no se ha vuelto obsoleto y regularmente recibe correcciones y nuevas funciones, ya que actualmente se usa como la base de la pila de draw.io , una popular aplicación comercial de creación de diagramas web que permite a los usuarios crear y compartir diagramas dentro de un navegador web. Esta aplicación ofrece información esclarecedora sobre la rica funcionalidad de mxGraph.

De hecho, mxGraph consiste principalmente en un archivo JS que incluye toda la funcionalidad de la biblioteca. La biblioteca no requiere complementos de terceros y se puede integrar en cualquier marco. En general, esta biblioteca es una solución estable, probada en producción y repleta de funciones, complementada con manuales de usuario.

Tipos de diagramas admitidos: BPMN, diagrama UML, diagrama de flujo, diagrama de árbol, mapa mental, diagrama de red, diagrama de Venn, diagrama de bastidor, diagrama de secuencia, diagrama FODA, plano de planta, infografía, diagrama eléctrico, diagrama de arquitectura AWS.

Integración con marcos JS: no encontrado

Disponibilidad de editores de diagramas: editor draw.io

Formatos de exportación de diagramas: no encontrado

Licencia y precio: gratis bajo licencia Apache 2.0

8) Organigrama JS (BalkanGraph)

OrgChart JS es un widget JS potente y, al mismo tiempo, fácil de usar que le permite ilustrar claramente las relaciones jerárquicas y las cadenas de mando dentro de la empresa de cualquier tamaño y complejidad por medio de organigramas intuitivos e interactivos.

Esta biblioteca proporciona un paquete de máscaras y paletas de colores predeterminadas para que la apariencia del gráfico encaje en el diseño de la aplicación. También hay una práctica función de búsqueda para una operación más conveniente con diagramas grandes. Gracias al formulario de edición integrado, los procesos de creación y edición de elementos del diagrama se simplifican enormemente: solo ingrese un nombre, título, información adicional y OrgChart JS agregará automáticamente el texto al nodo del diagrama.

Además, esta biblioteca ofrece las siguientes características útiles: personalización de nodos, arrastrar y soltar, expandir/contraer, carga diferida, zoom, barras de desplazamiento. Pero una de las mejores cosas de OrgChart JS es que no requiere ninguna habilidad de programación específica debido a la sintaxis de configuración simple (curva de aprendizaje suave).

Tipos de diagramas: organigrama

Integración con frameworks JS: Angular, React, Vue. js

Disponibilidad de editores de diagramas: formulario de edición personalizado

Formatos de exportación de diagramas: PDF, PNG, SVG, CSV

Licencia y precio: licencias comerciales desde 399$ hasta 4.999$

9) Biblioteca principal de Rapid/Jointjs

JointJS Core es un conjunto de herramientas completo para crear aplicaciones de modelado y creación de diagramas totalmente interactivas compatibles con los navegadores modernos, que se basan en JS y SVG. Esta biblioteca tiene muchas funciones integradas para trabajar cómodamente con gráficos y diagramas (numerosas formas listas para usar, filtros y degradados, elementos y enlaces interactivos, animaciones, arquitectura MVC, sistema de complemento flexible, etc.) y puede convertirse en una solución ideal para proyectos de código abierto.

Pero cuando se trata de aplicaciones comerciales, los desarrolladores pueden considerar usar Rappid, una extensión comercial de JointJS Core. Se basa en la base de JointJS y amplía significativamente su funcionalidad con la ayuda de numerosos componentes adicionales, lo que le permite implementar diferentes widgets de interfaz de usuario, elementos de interacción, diseños automáticos y otras herramientas útiles para crear aplicaciones visuales de última generación. Los tutoriales completos lo ayudarán a obtener una visión más profunda de la funcionalidad de este producto y aprender a usarlo de la manera más eficiente.

Tipos de diagramas admitidos: diagrama de flujo, diagrama BPMN, organigrama, diagrama UML, diagramas de árbol, diagrama similar a dibujado a mano

Integración con marcos JS: AngularJS, Backbone, React, Meteor y Bootstrap

Disponibilidad de editores de diagramas: Fregadero de cocina rápido

Formatos de exportación de diagramas: JSON, PNG, JPEG, SVG

Licencia y precio: Jointjs: licencia pública de Mozilla de código abierto v2.0. (libre); Rappid: licencias comerciales desde 1648$ por desarrollador

10) Sinfusión

La biblioteca de diagramas de Syncfusion es una solución rica en funciones para crear diagramas interactivos con la ayuda de cientos de formas predefinidas y personalizadas. Le permite crear un diagrama simple o complejo, ya sea mediante código o una interfaz visual. Utilizando una amplia gama de formas, nodos, conectores y puertos, puede ilustrar vívidamente los modelos de flujo de trabajo y los procedimientos comerciales, acompañando los componentes del diagrama con etiquetas y datos textuales. Es fácil realizar operaciones CRUD (agregar, editar, eliminar) para cualquier nodo o conector. El modo de virtualización ayuda a cargar rápidamente solo las formas visibles en la pantalla, lo que optimiza el rendimiento.

Gracias a una gran cantidad de funciones interactivas (rotar, seleccionar y arrastrar, rotar, agrupar, deshacer/rehacer), los diagramas se pueden editar fácilmente a su gusto. Los algoritmos de diseño automático avanzados ayudan a organizar los nodos y los conectores en función de un diseño predeterminado. Para trabajar cómodamente con diagramas grandes, es posible utilizar el panel de descripción general y las herramientas de zoom y panorámica. También es posible utilizar la función de serialización para guardar y cargar el estado de su diagrama cuando sea necesario. Los componentes principales del diagrama van acompañados de ejemplos y documentación para brindarle una imagen clara de sus capacidades funcionales.

Tipos de diagramas admitidos: diagrama de flujo, organigrama, mapa mental, diagrama de clase UML, BPMN, diagrama de carril de natación.

Integración con frameworks JS: Angular, React, Vue.js, Blazor

Disponibilidad de editores de diagramas: herramienta de dibujo

Formatos de exportación de diagramas: PNG, JPEG, BMP, SVG

Licencia y precio: incluido en la biblioteca de interfaz de usuario de Syncfusion, licencias comerciales desde 995 $ por desarrollador

11) Treant.js

Treant.js es una biblioteca de JavaScript para crear diagramas de árbol simples y coloridos con la ayuda de HTML, CSS y SVG. Utiliza la biblioteca Raphael para la implementación de SVG y animaciones. Las estructuras de árbol estándar se pueden enriquecer con elementos colapsables e interactivos. La biblioteca ofrece 2 enfoques estándar diferentes (Array y JSON) para la construcción y configuración de organigramas de árbol. La documentación de la API en Treant.js se puede dividir en 2 secciones principales: una está relacionada con las capacidades de configuración de gráficos estándar, mientras que la otra describe las opciones de configuración que se pueden aplicar para cada nodo por separado.

Tipos de diagramas admitidos: diagramas de árbol

Integración con marcos JS: no encontrado

Disponibilidad de editores de diagramas: no encontrado

Formatos de exportación de diagramas: no encontrado

Licencia y precio: MIT (gratis)

12) Organigrama Webix

Webix Organogram es un widget de JavaScript que se puede utilizar para crear diagramas jerárquicos que demuestran las relaciones entre los miembros del personal de una empresa o presentan varios elementos de algunas estructuras complejas. Este widget fácil de aprender hereda la API de TreeStore y DataStore y tiene una rica funcionalidad. Es totalmente compatible con todos los navegadores modernos y se ejecuta en dispositivos de pantalla táctil.

Cuando se trata de funcionalidades, cabe señalar que cada elemento de los organigramas se puede configurar (tamaño, relleno, margen, marcado HTML) de acuerdo con las necesidades de los usuarios. Es posible afinar la apariencia de todo el componente o de cada uno de sus elementos utilizando estilos CSS y aplicando plantillas. También es posible activar la funcionalidad de selección y agregar controladores de eventos para llevar a cabo acciones específicas después de seleccionar un elemento específico. Y por último, pero no menos importante, este widget permite realizar diferentes manipulaciones con bloques de lista para mostrar gráficos con dependencias jerárquicas complejas de una manera más comprensible.

Tipos de diagramas admitidos: organigrama

Integración con frameworks JS: jQuery, Angular, React, Vue.js, Backbone

Disponibilidad de editores de diagramas: no encontrado

Formatos de exportación de diagramas: PNG, Excel, PDF, CSV

Licencia y precio: incluido en el paquete de componentes de Webix UI, licencia comercial desde 449 $ por desarrollador

13) yArchivos para HTML

yFiles para HTML es parte de la popular familia de productos yFiles diseñada por yWorks para agregar diagramas sofisticados a aplicaciones web HTML5/JS. Esta biblioteca JS pura ofrece una variedad de herramientas de interfaz de usuario y capacidades de edición extendidas para crear y cambiar gráficos y diagramas de cualquier grado de complejidad.

Proporciona un gran conjunto de funciones de diagramación para una visualización de datos efectiva (actualizaciones dinámicas, interacción intuitiva, disposición automática de diagramas, etiquetado automático, amplias posibilidades de representación visual, diferentes algoritmos de enrutamiento, etc.). No es necesario utilizar complementos ni componentes de servidor para crear aplicaciones del lado del cliente. La disponibilidad de las últimas tecnologías de renderizado (SVG, WebGL y HTML5 Canvas) le brinda más libertad de acción al dibujar diagramas. La biblioteca también es compatible con las características actualizadas de ECMAScript 6 y permite el uso de enlaces de TypeScript. Gracias a tutoriales detallados y documentación de API bien estructurada, los desarrolladores pueden dominar todas las peculiaridades de esta biblioteca en muy poco tiempo.

Tipos de diagramas admitidos: diagrama de flujo, diagrama de carriles, diagrama UML, organigrama, genealogía, diagrama de procesos comerciales, análisis de redes sociales (diagramas con agrupamiento), jerarquías de gráficos anidados

Integración con frameworks JS: AngularJS, Angular 2+, ReactJS, Vue.js y otros frameworks JS.

Disponibilidad de editores de diagramas: editor de diagramas en línea

Formatos de exportación de diagramas: VSDX, PDF

Licencia y precio: licencia comercial de 11,900$ por desarrollador

Conclusión

En los últimos años, el ecosistema de la biblioteca de JavaScript para crear diagramas ha evolucionado significativamente para satisfacer la creciente demanda de visualización y análisis eficiente de big data en los procesos comerciales modernos. Hoy en día, el mercado de software puede ofrecer una amplia gama de soluciones de diagramación con diversos conjuntos de funcionalidades y características de rendimiento. Por lo tanto, puede convertirse en una tarea bastante complicada elegir la biblioteca de diagramas adecuada para un proyecto específico.

Afortunadamente, la mayoría de los productos descritos anteriormente ofrecen versiones de prueba gratuitas para darle una idea de sus capacidades operativas. Además, si tiene un presupuesto ajustado y no requiere funcionalidades complejas para su proyecto, puede utilizar mxGraph, Google Charts o Treant.js. Si está buscando un producto con la mejor relación precio/calidad, será razonable considerar DHTMLX Diagram con sus prácticas funciones de edición y alto rendimiento o Basic Primitives con una amplia variedad de tipos de diagramas. En caso de que su proyecto esté generosamente financiado, puede invertir en Rappid o yFiles para crear diagramas de cualquier nivel de complejidad.

Al elegir la mejor biblioteca de diagramas para sus necesidades, es mejor probar un par de bibliotecas usando sus datos. Le ayudará a encontrar la variante más adecuada para sus proyectos actuales o futuros.

Para acortar la historia, aquí hay un pequeño diagrama dibujado con la ayuda del editor de diagramas DHTMLX que puede ayudarlo a elegir la biblioteca más adecuada de acuerdo con varios criterios (código abierto versus comercial, independiente versus parte de bibliotecas de interfaz de usuario solamente, variedad de formas, disponibilidad de algoritmo de diseño automático y editores en vivo):