En la necesidad de crear formularios "dinámicos" como los de Google Forms, se buscaron las distintas librerías disponibles para ello.
Se usará Angular ya que se tiene experiencia con este framework UI, además servirá para enfocarnos en el núcleo del problema (que es hacer encuestas como las de Google Forms).
Dentro de las librerías existentes para Angular encontramos:
- @ng-dynamic-forms-core
- formio
- ng-formly
- ngx-forms
- otras
Según las estadísticas de npmtrends podemos ver que la comunidad desarrolladora ha usado durante varios años con más frecuencia @ngx-formly/core
. En segundo lugar está formio
y luego entontramos a @ng-dynamic-forms/core
. Podemos notar una extrema diferencia en las tendencias.
Dadas las tendencias entre los desarrolladores, se ejecutó una prueba con las tres librerías en donde las tres satisfacen los requisitos en cuanto al objetivo. Por otro lado, en cuanto a la configuración y extensión de controles personalizados la mejor es @ngx-formly/core
.
Lo otro muy bueno de ngx-formly es su variedad de frameworks UI, teniendo disponible Material UI
, Bootstrap
, ng-zorro-antd
, KendoUI
. En donde todas ellas son muy renombradas en el ámbito de la ingeniería frontend en el extranjero.
Luego de hacer una POC(Prove Of Concept), en donde se desarrollaron las siguientes pruebas:
- Utilizar ngx-forms
- Utilizar @ng-dynamic-forms-core
- formio
- ng-formly
- Componentes personalizados a través de un selector y generador.
Luego de medir la complejidad del desarrollo con las distintas herramientas, y buscando la facilidad y estandarización de datos, se trabajará con la opción 5; de esta manera estamos en posición de personalizar más aún cada componente que el cliente necesite y podemos estructurar los datos de tal forma de luego dar recomendaciones de preguntas semejantes o algún módulo inteligente.
En cuanto a los frameworks UI disponibles, de momento hay preferencia por ng-zorro-antd
, dada la diversidad de controles que posee. Además se está evaluando usar TailwindCss
para desarrollar más rápido el esqueleto de la aplicación.
Agrupan un formulario con título y descripción del formulario; además posee la funcionalidad de duplicar, mover o eliminar la sección.
Esta pertenece a una sección y tiene un campo de texto en donde se añade la pregunta. Permite añadir una imagen.
Posee un selector en donde uno puede elegir el tipo de control o de pregunta, los disponibles son:
- Respuesta corta
- Párrafo
- Varias opciones: Radio group vertical que deja seleccionar solo un elemento.
- Casillas: Checkboxes verticales que deja seleccionar múltiples elementos.
- Desplegable: select
- Subir archivos
- Escala lineal (radios horizontales)
- Cuadrícula de varias opciones (matriz de radios)
- Cuadrícula de casillas
- Fecha
- Hora
- Slider de porcentaje
Además posee las funcionalidades:
- Pregunta se puede mover de lugar en el formulario
- Tiene botón eliminar y duplicar.
- Tiene switch de si es obligatorio o no.
- Existe una librería para angular llamada ngx-formly-desinger, la cual implementa la creación de un formulario usando bootstrap. La idea es intentar extender la librería o adaptarla para nz-ant-design para homologar la UI.
- La segunda idea es utilizar componentes que contienen formularios dentro. (Sería la forma más simple).
Supongamos que hacemos las encuestas dinámicas:
Las preguntas serán ingresadas manualmente, por lo que no será facil establecer relaciones entre preguntas en los distintos semestres para luego visualizar los datos como se requieren. Es sabido gracias a la documentación proveída, que las preguntas en los años no cambian (y si cambiasen podemos crear una "enmienda" de la pregunta para no perder la trazabilidad de la pregunta).
Las opciones ingresadas tampoco serán estandar por lo que caeremos en la misma problemática anterior. Podremos visualizar resultados pero solo del semestre, será difícil establecer relaciones.
¿Y qué con un banco de preguntas dependiendo de la entidad que sea encuestada?:
Supongamos creamos un mantenedor de "temáticas", las cuales podrían ser:
- Evaluación por Alumno.
- Evaluación por Docente.
- Evaluación por Ayudante.
- Evaluación por para-docente.
El flujo debiese ser:
- Ir a módulo mantenedor de temáticas.
- Crear una entidad de temática, podemos proveer nombre de temática, descripción de temática, usuarios objetivos.
- Ir a módulo mantenedor de preguntas.
- Crear de forma rápida preguntas relacionadas a una temática antes inscrita en el sistema.
- Las preguntas deben tener tipo de control, opciones en caso de ser necesario.
- Crear de forma rápida preguntas relacionadas a una temática antes inscrita en el sistema.