Uso de plantillas Liquid
Las plantillas Liquid amplían significativamente las capacidades de personalización de Pushwoosh al implementar una lógica sofisticada además del uso regular del Contenido Dinámico.
La personalización de mensajes en Pushwoosh se basa en Etiquetas (datos de usuario). Pushwoosh ofrece una variedad de Etiquetas predeterminadas y Etiquetas personalizadas. Usándolas, puede especificar el nombre, la ciudad, el historial de compras, etc. del usuario para enviar un mensaje más personalizado, por ejemplo: Hola {First_name}, gracias por pedir {item}.
Las plantillas Liquid añaden más lógica al contenido dinámico. Por ejemplo, si la etiqueta de suscripción de un usuario contiene “gratis”, puede enviarle un mensaje: “Aprovecha tu 10% de descuento”.
Modificar el contenido del mensaje según las identificaciones, comportamientos y preferencias de los usuarios es la forma más eficiente de aumentar la relevancia y obtener resultados más impresionantes de sus campañas de marketing.
Sintaxis
Anchor link toLas plantillas de contenido basadas en Liquid de Shopify utilizan una combinación de etiquetas, objetos y filtros para cargar contenido dinámico. Las plantillas de contenido le permiten acceder a ciertas variables desde una plantilla y mostrar sus datos sin tener que saber nada sobre los datos en sí.
Objetos
Anchor link toLos objetos definen el contenido que se mostrará a un usuario. Los objetos deben estar encerrados en llaves dobles: {{ }}
Por ejemplo, al personalizar un mensaje, envíe {{Name}} en su cuerpo para agregar los nombres de los usuarios al contenido del mensaje. El nombre del usuario (valor de la etiqueta Name) reemplazará el objeto Liquid en el mensaje que el usuario verá.
Hi {{Name}}! We're glad you're back!¡Hola Anna! ¡Nos alegra que hayas vuelto!
Etiquetas
Anchor link toLas etiquetas crean la lógica y el flujo de control para las plantillas. Los delimitadores de llave y porcentaje {% y %} y el texto que rodean no producen ninguna salida visible cuando se renderiza la plantilla. Esto le permite asignar variables y crear condiciones o bucles sin mostrar ninguna de la lógica de Liquid a un usuario.
Por ejemplo, usando la etiqueta if, puede variar el idioma del mensaje según el idioma configurado en el dispositivo del usuario:
{% if Language == 'fr' %}Salut!{% else %}Hello!{% endif %}Salut!
Hello!
Operadores de etiquetas
Anchor link to| Operador | Descripción |
|---|---|
== | es igual a |
!= | no es igual a |
> | mayor que |
< | menor que |
>= | mayor o igual que |
<= | menor o igual que |
or | o lógico |
and | y lógico |
contains | comprueba la presencia de una subcadena dentro de una cadena o un array de cadenas |
Filtros
Anchor link toLos filtros modifican la salida de un objeto o variable Liquid. Se utilizan dentro de llaves dobles {{ }} y en la asignación de variables, y se separan por un carácter de barra vertical |. Se pueden usar múltiples filtros en una salida, y se aplican de izquierda a derecha.
{{ Name | capitalize | prepend:"Hello " }}Hello Anna
Uso de plantillas Liquid en mensajes enviados a través de la API
Anchor link toUse la sintaxis de Liquid en sus solicitudes createMessage para implementar plantillas Liquid. Las plantillas están disponibles para el parámetro “content” de la solicitud createMessage, así como para cualquier otro parámetro que admita Contenido Dinámico, en particular, los parámetros específicos de la plataforma “title”, “subtitle” e “image”.
Al usar plantillas de contenido, puede especificar los datos en sus solicitudes de API (pasando el parámetro “template_bindings”) u obtener los datos de los valores de las Etiquetas almacenados en los dispositivos de los usuarios (al no usar el parámetro “template_bindings”). De esta manera, puede crear campañas push basadas en el usuario que contienen contenido extremadamente relevante.
Para definir la lógica de la plantilla usando las Etiquetas con espacios en sus nombres, use la siguiente técnica:
Ejemplo
{% capture my_tag %}{{My Tag}}{% endcapture %}{% if my_tag == 'value' %}Contenido a enviar en este caso{% else %}Contenido a enviar en caso contrario{% endif %}Casos de uso de las plantillas Liquid
Anchor link toAquí encontrará varios casos de uso en los que las plantillas Liquid son útiles.
Push multilingüe
Anchor link toLas plantillas Liquid hacen posible especificar definitivamente en qué idioma los usuarios deben recibir sus mensajes push. Observe el ejemplo simple de la solicitud de API y el mensaje recibido dependiendo de los enlaces de plantilla utilizados en la solicitud.
{% if Language == 'es' %}¡Hola!{% else %}Hello!{% endif %}{ "request": { "application": "XXXXX-XXXXX", // Pushwoosh app code "auth": "yxoPUlw.....IyEX4H", // API access token from Pushwoosh Control Panel "notifications" : [ // push message parameters { "content": "{% raw %}{% if language == 'es' %}¡Hola!{% else %}hello!{% endif %}{% endraw %}", "template_bindings": { // optional. When no template_bindings are passed in a request, Tag values from the device are used. "language" : "es" } } ] }}El idioma es ‘es’: ¡Hola!
El idioma es ‘en’: Hello!
Mensaje de actualización de suscripción
Anchor link toAnime a sus clientes a actualizar su suscripción según su plan actual.
{% if Subscription == 'Basic' %} Upgrade to Silver for getting more product features and 24/7 support.{% elsif Subscription == 'Silver' %} Upgrade to Gold for priority support and advanced features.{% else %} Please contact your manager to renew your subscription.{% endif %}{ "request": { "application": "XXXXX-XXXXX", // Pushwoosh app code "auth": "yxoPUlw.....IyEX4H", // API access token from Pushwoosh Control Panel "notifications" : [ // push message parameters { "content": "{% raw %}{% if Subscription == 'Basic' %}Upgrade to Silver for getting more product features and 24/7 support.{% elsif Subscription == 'Silver' %}Upgrade to Gold for priority support and advanced features.{% else %}Please contact your manager to renew your subscription. {% endif %}{% endraw %}", "template_bindings": { // optional. When no template_bindings are passed in a request, Tag values from the device are used. "language" : "es" } } ] }}Para usuarios con plan de suscripción Básico: Upgrade to Silver for getting more product features and 24/7 support.
Para usuarios con plan de suscripción Silver: Upgrade to Gold for priority support and advanced features.
Para usuarios con otros planes: Please contact your manager to renew your subscription.
Etiquetas de lista
Anchor link toLas plantillas de contenido son bastante útiles para manejar Etiquetas de tipo Lista.
Tamaño variable
Anchor link toUno de los posibles casos de uso es entregar contenido diferente dependiendo del número de valores que contiene la Etiqueta. Por ejemplo, puede ofrecer diferentes descuentos a clientes con diferentes comportamientos. Digamos que el cliente tiene algunos artículos en su Lista de Deseos: ¡anímelo a comprar con el descuento más adecuado según la cantidad de productos que va a comprar!
{% if WishList.size >= 3 %}Get 20% off your next purchase!{% elsif WishList.size == 2 %}Get a 10% discount on your next purchase!{% else %}Hey, take a look at new outwears!{% endif %}{ "request": { "application": "XXXXX-XXXXX", // Pushwoosh app code "auth": "yxoPUlw.....IyEX4H", // API access token from Pushwoosh Control Panel "notifications" : [ // push message parameters { "content": "{% raw %}{% if WishList.size >= 3 %}Get 20% off your next purchase!{% elsif WishList.size == 2 %}Get a 10% discount on your next purchase!{% else %}Hey, take a look at new outwears!{% endif %}{% endraw %}", "template_bindings": { "WishList" : ["Skinny Low Ankle Jeans", "Linen Trenchcoat", "High Waisted Denim Skirt", "Strappy Tiered Maxi Dress"] } } ] }}

La variable contiene
Anchor link toOtro caso que podría necesitar cubrir es tratar con los valores de las Etiquetas de Lista y entregar el contenido más relevante según los valores que contiene la Etiqueta.
{% if WishList contains 'Skinny Low Ankle Jeans' %}Get 20% off products in your wishlist!{% else %}Hey, take a look at the brand new Skinny Low Ankle Jeans!{% endif %}{ "request": { "application": "C90C0-0E786", "auth": "yxoPUlw.....IyEX4H", // API access token from Pushwoosh Control Panel "notifications" : [ // push message parameters { "content": "{% raw %}{% if WishList contains 'Skinny Low Ankle Jeans' %}Get 20% off your next purchase!{% else %}Hey, take a look at the brand new Skinny Low Ankle Jeans!{% endif %}{% endraw %}", "template_bindings": { "WishList" : ["Skinny Low Ankle Jeans", "Linen Trenchcoat", "High Waisted Denim Skirt", "Strappy Tiered Maxi Dress"] } } ] }}

Plurales
Anchor link toAl usar las plantillas de contenido, puede ajustar el contenido del mensaje según el comportamiento de los usuarios. Por ejemplo, puede modificar el texto del mensaje para que contenga palabras en plural en caso de que la Etiqueta de Lista contenga más de un valor.
Get 20% off item{% if WishList.size > 1 %} s in your WishList!{% else %} in your Wishlist!{% endif %}{ "request": { "application": "C90C0-0E786", "auth": "yxoPUlw.....IyEX4H", // API access token from Pushwoosh Control Panel "notifications" : [ // push message parameters { "content": "Get 20% off item{% raw %}{% if WishList.size > 1 %}s in your WishList!{% else %} in your Wishlist!{% endif %}{% endraw %}", "template_bindings": { // optional. When no template_bindings are passed in a request, Tag values from the device are used. "WishList" : ["Skinny Low Ankle Jeans", "Linen Trenchcoat", "High Waisted Denim Skirt", "Strappy Tiered Maxi Dress"] } } ] }}

Zona horaria
Anchor link toLa plantilla para zonas horarias convierte la fecha y la hora según la zona horaria especificada.
{{ MyDate | timezone: MyTimezone | date: \"%Y-%m-%d %H:%M\" }}{ "request" : { "auth" : "3H9bk8w3.....Acge2RbupTB", // API access token from Pushwoosh Control Panel "application" : "XXXXX-XXXXX", // Pushwoosh app code "notifications" : [ // push message parameters { "content": "Current Date: {{ MyDate | timezone: MyTimezone | date: \"%Y-%m-%d %H:%M\" }}", "template_bindings": { // optional. When no template_bindings are passed in a request, Tag values from the device are used. "MyDate" : "2019-07-23 15:00", "MyTimezone" : "Asia/Dubai" } } ] }}
Contenido conectado
Anchor link toEl contenido conectado es una característica en las plantillas Liquid que le permite recuperar y usar dinámicamente datos de una fuente externa, como un servicio web, directamente dentro de sus mensajes de correo electrónico o notificación push. Esta característica permite la personalización en tiempo real al obtener datos JSON de una URL especificada y guardarlos en una variable que se puede utilizar en su contenido.
Casos de uso clave
Anchor link to-
Recomendaciones de productos: Muestre listas de productos personalizadas adaptadas a cada usuario.
-
Códigos promocionales: Inserte códigos promocionales únicos generados por un servicio de backend.
Prerrequisitos
Anchor link to- Para usar el Contenido Conectado, debe tener su propio servicio de backend que genere y proporcione los datos requeridos (por ejemplo, códigos promocionales, recomendaciones de productos) basados en el ID de Usuario, HWID o etiquetas personalizadas. Pushwoosh luego obtiene estos datos antes de enviar un mensaje.
Guía de implementación paso a paso
Anchor link toPaso 1. Configurar el servicio de backend
Anchor link toEl servicio de backend debe:
- Aceptar una solicitud que contenga parámetros específicos del usuario (por ejemplo,
userId). El Contenido Conectado admiteUserID,HWIDo cualquier etiqueta personalizada que haya configurado en su proyecto. - Devolver una respuesta JSON con los datos requeridos. Este contenido se puede insertar dinámicamente en los mensajes.
Paso 2. Crear un preset con Contenido Conectado en Pushwoosh
Anchor link to- En el editor de contenido de Push o Email, inserte la sintaxis de Contenido Conectado en el campo del mensaje.
Ejemplo
{% connected_content http://your-backend-url.com?userId={{ ${userid} }} :save result %}Desglose de la sintaxis
connected_content | Obtiene datos JSON de la URL de backend especificada. |
http://your-backend-url.com | El punto final del backend que devuelve los datos requeridos en formato JSON. |
userId={{ ${userid} }} | Un parámetro de consulta dinámico que pasa el ID de usuario al backend. |
:save result | Almacena la respuesta JSON obtenida en la variable result para su uso en plantillas Liquid. |

Autenticación (opcional)
Si su servicio de backend requiere autenticación, puede incluir una clave de API o un token en la solicitud de Contenido Conectado para garantizar un acceso seguro.
{% connected_content http://your-backend-url.com?userId={{ ${userid} }}&auth=YOUR_API_KEY :save result %}Uso de etiquetas en Contenido Conectado
Para incluir etiquetas personalizadas, insértelas como parámetros de consulta en la solicitud de Contenido Conectado ({{ tag_name }}).
{% connected_content http://your-backend-url.com?userId={{ ${userid} }}{{ Language }} :save result %}- A continuación, agregue el texto del mensaje incorporando los datos recuperados, de esta manera:
Hey, {{userid}}, grab your personal promo code - {{result.code}}
- Después de finalizar el contenido del mensaje y configurar los ajustes del preset, guárdelo para reutilizarlo en campañas.
Paso 3. Enviar un mensaje usando el preset configurado
Anchor link toEnvíe un mensaje con este preset usando el formulario de push único o de correo electrónico o un customer journey.