File size: 9,026 Bytes
6cbfd9d
 
 
 
f676589
6cbfd9d
 
 
 
 
 
 
c40d623
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
a6e117c
c40d623
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
a6e117c
c40d623
 
 
 
 
 
 
a6e117c
c40d623
9bac898
 
 
 
0fab3b6
 
c40d623
0fab3b6
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
9bac898
 
6cbfd9d
9bac898
6cbfd9d
ac82a75
 
 
c40d623
 
ac82a75
6cbfd9d
c40d623
6cbfd9d
c40d623
e411757
ac82a75
 
c40d623
 
ac82a75
 
c40d623
 
ac82a75
 
 
c40d623
ac82a75
c40d623
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
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.35, 0.25, 0.40]
    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=(
            f"Eres un experto copywriter especializado en escribir mensajes o textos que atraen la atenci贸n de {target_audience} para promover {product} que soluciona los problemas de {target_audience}. "
            "Tu tarea es ayudarme a escribir llamados a la acci贸n (CTA) para mi [p谩gina web, landing, correo],"
            f"teniendo en cuenta los puntos dolorosos de mi {target_audience} y el {product} y la {call_to_action} 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"
            "Los llamados de acci贸n deben de ser cortos y concisos, 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")

# Centrar el t铆tulo y el subt铆tulo
st.markdown("<h1 style='text-align: center;'>Quick Prompt</h1>", unsafe_allow_html=True)
st.markdown("<h4 style='text-align: center;'>Transforma tu mensaje en llamados de acci贸n que inspiren a tu audiencia a tomar decisiones al instante.</h4>", unsafe_allow_html=True)

# A帽adir CSS personalizado para el bot贸n
st.markdown("""
    <style>
    div.stButton > button {
        background-color: #FFCC00;
        color: black;
        width: 90%;
        height: 60px;
        font-weight: bold;
        font-size: 22px;
        text-transform: uppercase;
        border: 1px solid #000000;
        border-radius: 8px;
        display: block;
        margin: 0 auto;
    }
    div.stButton > button:hover {
        background-color: #FFD700;
        color: black;
    }
    </style>
""", unsafe_allow_html=True)

# Crear columnas
col1, col2 = st.columns([1, 2])  

# Columnas de entrada
with col1:
    target_audience = st.text_input("驴Qui茅n es tu p煤blico objetivo?", placeholder="Ejemplo: Estudiantes Universitarios")
    product = st.text_input("驴Qu茅 producto tienes en mente?", placeholder="Ejemplo: Curso de Ingl茅s")
    call_to_action = st.text_input("驴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"""
                <div style="border: 1px solid #000000; padding: 5px; border-radius: 8px; background-color: #ffffff;">
                    <h4>Mira los llamados a la acci贸n generados:</h4>
                    <p style="font-size: 22px;">{generated_ctas}</p>
                </div>
            """, unsafe_allow_html=True)
        except Exception as e:
            st.error(f"Error al generar los llamados a la acci贸n: {str(e)}")
    else:
        st.error("Por favor, completa todos los campos.")