from dotenv import load_dotenv import streamlit as st import os import google.generativeai as genai import random # Cargar las variables de entorno load_dotenv() # Configurar la API de Google genai.configure(api_key=os.getenv("GOOGLE_API_KEY")) # Función para obtener una mención del producto de manera probabilística def get_random_product_mention(): mentions = ["Directa", "Indirecta", "Metafórica"] probabilities = [0.34, 0.33, 0.33] return random.choices(mentions, probabilities)[0] # Crear la instrucción de mención basada en la opción seleccionada def get_mention_instruction(product_mention, product): if product_mention == "Directa": return f"Introduce directamente el producto '{product}' como la solución clara al problema que enfrenta el lector." elif product_mention == "Indirecta": return f"Referencia sutilmente el producto '{product}' como una posible solución al problema del lector sin nombrarlo explícitamente." elif product_mention == "Metafórica": return f"Introduce el producto '{product}' usando una metáfora, conectándolo simbólicamente a la solución que necesita el lector." return "" # Ejemplos de llamados a la acción por tipo cta_types = { "directos": [ "Descargar la guía para mejorar mi productividad diaria.", "Suscribirme para recibir actualizaciones y promociones exclusivas.", "Unirme a la prueba gratis de 14 días y descubrir nuevas funciones.", "Registrarme para acceder a contenido premium y estrategias efectivas.", "Comprar ahora y obtener un regalo especial con mi pedido." ], "urgencia": [ "Inscribirme ahora para asegurar mi lugar antes de que se agoten las plazas.", "Comenzar mi transformación hoy y no perder más tiempo." ], "descuento": [ "Aprovechar el 50% de descuento y comprar por tiempo limitado.", "Hacer mi pedido ahora y obtener un 30% de descuento adicional." ], "exclusividad": [ "Acceder a contenido exclusivo solo para miembros.", "Ser parte de un grupo selecto y disfrutar de beneficios únicos." ], "beneficio_claro": [ "Mejorar mi productividad en solo una semana.", "Transformar mi carrera profesional con herramientas avanzadas." ], "personalización": [ "Descubrir cómo personalizar esta oferta para mis necesidades.", "Elegir las opciones que mejor se adapten a mis necesidades." ] } # Función para que el modelo elija automáticamente el tipo de CTA y el CTA específico def get_random_cta(): cta_type = random.choice(list(cta_types.keys())) # Selección aleatoria del tipo de CTA cta = random.choice(cta_types[cta_type]) # Selección aleatoria del CTA dentro del tipo return cta # Función para generar llamados a la acción def generate_ctas(number_of_ctas, target_audience, product, call_to_action, temperature): product_mention = get_random_product_mention() mention_instruction = get_mention_instruction(product_mention, product) # Configuración del modelo generation_config = { "temperature": temperature, "top_p": 0.85, "top_k": 128, "max_output_tokens": 2048, "response_mime_type": "text/plain", } # Configuración del modelo generativo y las instrucciones del sistema model = genai.GenerativeModel( model_name="gemini-1.5-flash", # Nombre del modelo que estamos utilizando generation_config=generation_config, # Configuración de generación system_instruction=( "Eres un experto copywriter especializado en productos que solucionan problemas de tus clientes. " "Tu tarea es ayudarme a escribir llamados a la acción (CTA) para mi [página web, landing, correo], " "teniendo en cuenta los puntos débiles de mi [cliente ideal] y el [producto] y la [acción] a realizar. " "Recuerda que un buen CTA debe tener:\n\n" "1. **Acción**: Palabras que invitan a realizar un movimiento (e.g., 'Descargar', 'Suscribirse').\n" "2. **Valor**: Explicar el beneficio que el usuario obtendrá al realizar la acción.\n\n" "Asegúrate de que cada llamado a la acción siga la estructura de 'Acción + conector + Valor', y evita incluir explicaciones como 'Acción: Descubrir' o 'Valor: Un oasis de paz en medio del caos'.\n" "Important: Only answer CTAs, never include explanations or categories, like this: 'Registrarme ahora y descubrir cómo encontrar un poco de paz en medio del caos. (Este CTA apela al deseo de Han Solo de encontrar un momento de tranquilidad en su vida agitada.).'\n" "Basate en estos ejemplos para realizar tu tarea de crear los CTA's:\n\n" "**Ejemplos de CTAs en Voz Activa en Primera Persona:**\n" "- 'Descargar la guía para mejorar mi productividad diaria'\n" "- 'Suscribirme para recibir actualizaciones y promociones exclusivas'\n" "- 'Unirme a la prueba gratis de 14 días y descubrir nuevas funciones'\n" "Usa estos lineamientos para generar CTAs de alta conversión en español." ) ) # Selección aleatoria de tipos de CTA, manteniendo variedad en la salida selected_types = random.sample(list(cta_types.keys()), min(number_of_ctas, len(cta_types))) # Crear un mensaje para el modelo que incluye los CTAs generados según los tipos seleccionados ctas_instruction = ( f"Tu tarea es crear {number_of_ctas} llamados a la acción efectivos dirigidos a {target_audience}, " f"para promover {call_to_action}. Usa la siguiente mención: {mention_instruction}. " "Asegúrate de que cada llamado a la acción siga la estructura de 'Acción + conector + Valor', " "como los ejemplos proporcionados anteriormente." ) # Generar el resultado utilizando el modelo con la instrucción de CTA específica try: response = model.generate_content([ctas_instruction]) # Extraer el texto de la respuesta generated_ctas = response.candidates[0].content.parts[0].text.strip() # Modificado aquí # Retornar el resultado return generated_ctas except Exception as e: raise ValueError(f"Error al generar los CTA: {str(e)}") # Configurar la interfaz de usuario con Streamlit st.set_page_config(page_title="QuickPrompt", layout="wide") # Agregar el manual en el sidebar con mejor diseño st.sidebar.markdown("## **Manual de Usuario para Quick Prompt**") st.sidebar.write(""" **Bienvenido a Quick Prompt** Quick Prompt está diseñado para ayudarte a crear llamados a la acción (CTAs) que motiven a tu audiencia a actuar de inmediato. ### ¿Por qué los CTAs son importantes? Los CTAs son el puente que conecta a tu audiencia con tu producto o servicio. Aquí te mostramos algunos ejemplos de acciones comunes: - Descargar un PDF con recursos útiles - Inscribirse en un evento o webinar - Participar en una oferta exclusiva ### ¿Cómo utilizar Quick Prompt? Sigue estos pasos para sacar el máximo provecho de la herramienta: 1. **Define tu público objetivo** Piensa en quiénes son y qué necesitan. Por ejemplo: - Estudiantes universitarios en busca de mejorar su productividad - Emprendedores que necesitan aprender marketing digital - Profesionales buscando mejorar su gestión del tiempo 2. **Especifica tu producto o servicio** Asegúrate de que el producto esté claro y relacionado con el CTA. Ejemplos: - Guía gratuita sobre técnicas de estudio - Curso online de marketing para emprendedores - Webinar sobre gestión del tiempo 3. **Determina la acción deseada** Define cuál es la acción específica que deseas que realice tu audiencia: - Descargar un PDF - Inscribirse a un curso online - Registrarse para un webinar 4. **Ajusta la creatividad de tu CTA** Quick Prompt te permite ajustar el nivel de creatividad de tus CTAs. Algunos ejemplos: **Creatividad Baja (0.0 - 0.3)** - "Descarga la guía gratuita sobre productividad." - "Inscríbete al curso hoy." - "Regístrate para el webinar ahora." **Creatividad Media (0.4 - 0.7)** - "Mejora tu día con nuestra guía gratuita. ¡Descárgala ahora!" - "Únete a nuestro curso y empieza a crecer hoy mismo." - "Regístrate para el webinar y descubre nuevas oportunidades." **Creatividad Alta (0.8 - 1.0)** - "¡Conquista tu productividad con nuestra guía esencial! Descárgala ahora." - "Dale un giro a tu carrera. Únete al curso y transforma tu futuro hoy." - "No te pierdas esta oportunidad única. Regístrate y asegura tu lugar en el webinar." ### Consejos adicionales: - Si buscas algo más conservador, usa un valor de creatividad bajo. - Si necesitas ideas frescas y atrevidas, opta por un valor más alto. """) # Footer del manual st.sidebar.write("With Quick Prompt, transforming interest into action has never been easier.") # Centrar el título y el subtítulo st.markdown("

Quick Prompt

", unsafe_allow_html=True) st.markdown("

Transforma tu mensaje en llamados de acción que inspiren a tu audiencia a tomar decisiones al instante.

", unsafe_allow_html=True) # Añadir CSS personalizado para el botón st.markdown(""" """, unsafe_allow_html=True) # Añadir CSS personalizado para los campos de entrada flexibles st.markdown(""" """, unsafe_allow_html=True) # Crear columnas col1, col2 = st.columns([1, 2]) # Columnas de entrada with col1: target_audience = st.text_area("¿Quién es tu público objetivo?", placeholder="Ejemplo: Estudiantes Universitarios") product = st.text_area("¿Qué producto tienes en mente?", placeholder="Ejemplo: Curso de Inglés") call_to_action = st.text_area("¿Qué acción deseas que tomen?", placeholder="Ejemplo: Inscribirse al curso") number_of_ctas = st.selectbox("Número de llamados a la acción", options=[1, 2, 3, 4, 5], index=2) temperature = st.slider("Creatividad", min_value=0.0, max_value=1.0, value=0.5, step=0.1) # Botón de enviar submit = st.button("Generar Llamados a la Acción") # Mostrar los llamados a la acción generados if submit: if target_audience and product and call_to_action: try: # Obtener la respuesta del modelo generated_ctas = generate_ctas(number_of_ctas, target_audience, product, call_to_action, temperature) col2.markdown(f"""

¡Acción mágica en marcha!

{generated_ctas}

""", unsafe_allow_html=True) except ValueError as e: col2.error(f"Error: {str(e)}") except Exception as e: col2.error(f"Error inesperado: {str(e)}") else: col2.error("Por favor, proporciona el público objetivo, el producto y la acción.")