Evento solidario para ayudar a Jhonny Suarez

Abatic, empresa dedicada a la consultoría, formación y desarrollo de software ha convocado el primer "Delphi meet", encuentro de desarrolladores Delphi, que consiste en una reunión virtual a través de la plataforma Zoom, en la que se debaten temas relacionados con la tecnología.

La próxima reunión del 7 de Octubre a las 15:30 Hora de Madrid / España tendrá un carácter solidario, ya que todos los beneficios irán destinados a la familia de Jhonny Suarez, que se encuentra actualmente en un delicado estado de salud provocado por el COVID y por otra enfermedad respiratoria que tenía anteriormente.

Jhonny Suarez es creador y fundador del podcast "No sólo Delphi".

Espero Johnny que te mejores pronto y puedas seguir brindándonos la oportunidad de seguir escuchándote y desarrollando tu labor como programador y divulgador.

El contenido de este evento será el siguiente:

  • Sesión inicial de 30 minutos por parte de Emilio Pérez
  • 2’5 horas de Preguntas y Respuestas relacionadas con el mundo Delphi donde iremos respondiendo entre todos los asistentes y tendrá como moderador a Emilio Pérez.
  • Podrás participar activamente y en directo con el resto de compañeros de la comunidad Delphi.
  • Tendrás acceso al vídeo del directo para poder verlo las veces que necesites
  • Cupón de descuento del 75% para la academia online TodoPostgreSQL
  • Cupón de descuento del 100% para la academia online No Solo Delphi
  • Podrás aportarnos tu cupón que lo incluiremos en este curso y así más programadores Delphi podrán conocerte y tener un buen descuento en tus productos/servicios

Para los que quieran inscribirse y hacer una donación a la familia de Jhonny pueden hacerlo desde aquí.

Si quieren conocerle un poco más, aquí tienen el enlace a su página en Linkedin.



Programa complejo resuelto con una línea de código en Delphi

Partimos del supuesto que recibimos el encargo de realizar un programa en Delphi que debe hacer una llamada a una API, la cual nos devuelve un resultado en formato JSON, con 1000 campos, pero sólo queremos visualizar 3 de ellos (URL, TITLE, EXPLANATION) en el formulario de presentación al cliente.

¿Cómo hacemos esto de una forma visual en Delphi?, pues a continuación les explico detalladamente los pasos a seguir:


Añadimos un componente tRestResponseDataSetAdapter, un tFDMemTable y para hacer pruebas un tStringGrid, que nos mostrará todo el conjunto de datos

En la propiedad "Dataset" del tRestResponseDataSetAdapter seleccionamos FDMemTable1 y en "Response" selecciono "RESTResponse1"

Con el botón derecho del ratón pulsamos sobre el componente FDMemtable1 y seleccionamos AddBindSource, con lo se creará otro componente llamado "BindSourceDB1"

Volvemos a pulsar con el botón derecho del ratón sobre FDMemTable1 y seleccionamos Bind Visually... y se abrirá una nueva ventana llamada "LiveBindings Designer" 


 Si vinculamos FDmemTable1 con el componente StringGrid1, uniendo con el ratón los campos marcados con un asterisco, de esta forma:


al iniciar el programa llamando a "Execute", de esta forma:

PROCEDURE TFORM1.INICIO;
BEGIN
	RESTRequest1.Execute;
END;

veremos que los 1000 campos que nos ha devuelto la API se ven el Grid, que no es lo queremos en este caso, ya que únicamente necesitamos que se muestren en pantalla 3 de ellos, entonces ¿cómo se hace esto?, pues gracias al componente tBindingsList    ¡Este es el truco de magia!

1) Hacemos doble clic sobre el componente BindingsList1


(que se habrá creado al hacer la vinculación anterior)

 


 2) Sobre el apartado Bind Components hacemos clic con el botón derecho y seleccionamos la opción "New LinkControlToField1" y hacemos clic sobre esa nueva línea que se habrá creado para ver las propiedades en el Inspector de Objetos.


 

Allí en la propiedad "DataSource" seleccionamos "BindSourceDB1"  y en "FieldName" escribimos "Title" (es uno de los campos que nos interesa visualizar)


Cerramos la ventana de Edición del BindingsList y Actualizamos la ventana "LiveBindings Designer" haciendo clic con el botón derecho del ratón y activando el menú "Refresh Designer" y veremos que se ha creado un nuevo ítem "Title (Invalid)", lo de Invalid me imagino que es por que el dataset está cerrado en la fase de diseño.

y hacemos lo mismo para los otros dos campos.
Después sólo queda vincular los ítems "Title (invalid), url (invalid) y explanation (invalid)" a los componentes tEdit-Text, uniendo con el ratón los campos anteriores con el campo "Text", tal como se muestra en la imagen:

 

Eliminamos el componente "StringGrid1"

Y eso es todo, ahora al ejecutar el programa

PROCEDURE TFORM1.INICIO;
BEGIN
	RESTRequest1.Execute;
END;
 

Veríamos el resultado que nos interesa, lo que se traduce en una mayor rapidez de ejecución del programa, ya que nos ahorramos procesar 997 campos, de los 1000 que devuelve la API.


Además, como han podido ver, todo se ha hecho de forma visual con sólo 1 línea de código, simplemente asombroso y es que además este mismo programa funciona en Android, IOS, Linux y Windows y la portabilidad es instantánea.

¿A que merece la pena pasarse a Delphi?


Utilizar los componentes REST con Delphi

En esta ocasión veremos cómo hacer llamadas REST utilizando los componentes que nos proporciona Delphi 10.4.1

Desde el menú Tools, accedemos a la opción REST Debugger, y se abrirá un programa desarrollado por Embarcadero realizado para simplificar las consultas web y ver, entre otras cosas el header, body, los datos en formato tabular, cuando se hacen llamadas a una API. En cierto modo es parecido al funcionamiento del comando curl en Linux. 


 

 

En este caso voy a hacer una consulta a la API que nos proporciona la NASA para ver la foto del día.

https://api.nasa.gov/planetary/apod?api_key=DEMO_KEY&date=2021-08-15

En el campo URL pondremos la URL anterior, y dado que la consulta devuelve el resultado en formato JSON, en el Content-type seleccionaremos application/json

Pulsamos el botón "Send Request" y si todo ha ido bien en la parte inferior de la ventana, etiquetada con el nombre "Response" veremos la respuesta del Servidor (Headers, Body y Tabular Data)


Pulsamos el botón  "Copy components", para copiar en el clipboard los componentes (RestClient, RestRequest y RestResponse)



A continuación tenemos que crear una nueva aplicación:

Empezamos como siempre desde File -New - MultiDevice Application y añadimos 2 componentes: un tButton y un tMemo

Ahora tenemos que pegar los componentes anteriores sobre la vista de formulario de nuestro programa pulsando Ctrl+V, y quedará como sigue:


Añadimos a la ventana del Form un TButton y un TMemo, que contendrá el archivo JSON devuelto por la API

Sobre el form, con el botón derecho del ratón, activamos el menú "Bind Visually..." para que se abra el "LiveBindings Designer"

y unimos con el ratón los campos JSONText y Text (del tMemo) como muestra la figura:


 

En el botón insertamos la siguiente línea de código:

PROCEDURE TForm1.Button1Click(Sender: TObject);
BEGIN
  BEGIN
    RESTRequest1.Execute;
  END;
END;



Ejecutamos el programa y pulsamos el botón "Iniciar" del Form y nos mostrará la información que nos ha devuelto la llamada a la API



Si no quieren utilizar el LiveBindings Designer, tendrían que poner el siguiente código en el botón INICIAR.
PROCEDURE TForm1.Button1Click(Sender: TObject);
BEGIN
  VAR
    jValue: TJSONValue;
  BEGIN
    RESTRequest1.Execute;
    jValue := RESTResponse1.JSONValue;
    Memo1.Text := jValue.ToString;
  END;
END;

------------

En los siguientes Post les indicaré como dar formato tabular al JSON para que se pueda visualizar desde un DataSet, desde un StringGrid o utilizando una tabla en memoria para hacer consultas.