PromptWizardry / app.py
awacke1's picture
Update app.py
915e515 verified
raw
history blame
13.2 kB
import streamlit as st
import pandas as pd
import random
# Set page configuration
st.set_page_config(page_title="ChatGPT Prompt Generator", page_icon="๐Ÿง ", layout="wide")
# Custom CSS for horizontal button rows
st.markdown("""
<style>
.main {background-color: #f8f9fa;}
.stButton button {
border-radius: 4px;
padding: 2px 4px;
font-size: 0.75em;
margin: 1px;
white-space: nowrap;
}
.stButton button:hover {background-color: #e9ecef;}
div[data-testid="stVerticalBlock"] {gap: 0.2rem;}
div[data-testid="stHorizontalBlock"] {gap: 0.3rem;}
.stTextArea textarea, .stTextInput input {
padding: 0.2rem;
font-size: 0.8em;
}
h1, h2, h3 {margin-top: 0; margin-bottom: 0.1rem; font-size: 0.9rem;}
p, div {margin-bottom: 0.1rem; font-size: 0.8rem;}
.category-row {
background-color: white;
border: 1px solid #e6e6e6;
border-radius: 4px;
padding: 5px;
margin-bottom: 5px;
}
.category-label {
font-weight: bold;
font-size: 0.85rem;
color: #333;
margin-right: 5px;
margin-bottom: 3px;
display: block;
}
.horizontal-buttons {
display: flex;
flex-wrap: wrap;
gap: 2px;
align-items: center;
}
.prompt-display {
background-color: #ffffff;
border-radius: 4px;
padding: 8px;
border: 1px solid #e9ecef;
min-height: 100px;
font-size: 0.8em;
white-space: pre-wrap;
}
</style>
""", unsafe_allow_html=True)
# Initialize session state for selections
if 'selections' not in st.session_state:
st.session_state.selections = {
'role': None, 'tone': None, 'instruction': None, 'length': None,
'content_type': None, 'audience': None, 'format': None,
'about': "", 'inclusion': "", 'exclusion': "", 'input_data': ""
}
# Data sets
data = {
'roles': [
{"name": "Professional", "emoji": "๐Ÿ‘”"}, {"name": "Expert", "emoji": "๐Ÿง "},
{"name": "Friend", "emoji": "๐Ÿค"}, {"name": "Copywriter", "emoji": "โœ๏ธ"},
{"name": "Creative Writer", "emoji": "๐Ÿ–‹๏ธ"}, {"name": "Sales Coach", "emoji": "๐Ÿ’ผ"},
{"name": "Marketing Coach", "emoji": "๐Ÿ“Š"}, {"name": "Tech Consultant", "emoji": "๐Ÿ’ป"},
{"name": "Life Coach", "emoji": "๐Ÿง˜"}, {"name": "Data Analyst", "emoji": "๐Ÿ“ˆ"},
{"name": "Influencer", "emoji": "๐Ÿ“ฑ"}, {"name": "Language Tutor", "emoji": "๐Ÿ—ฃ๏ธ"},
{"name": "Fitness Trainer", "emoji": "๐Ÿ’ช"}, {"name": "Teacher", "emoji": "๐Ÿ‘จโ€๐Ÿซ"},
{"name": "Therapist", "emoji": "๐Ÿง"}, {"name": "Detective", "emoji": "๐Ÿ”"}
],
'tones': [
{"name": "Informative", "emoji": "โ„น๏ธ"}, {"name": "Inspirational", "emoji": "โœจ"},
{"name": "Humorous", "emoji": "๐Ÿ˜„"}, {"name": "Friendly", "emoji": "๐Ÿ˜Š"},
{"name": "Professional", "emoji": "๐Ÿ‘”"}, {"name": "Casual", "emoji": "๐Ÿ‘‹"},
{"name": "Persuasive", "emoji": "๐Ÿค"}, {"name": "Encouraging", "emoji": "๐Ÿ™Œ"},
{"name": "Empathetic", "emoji": "๐Ÿค—"}, {"name": "Serious", "emoji": "๐Ÿ˜"},
{"name": "Enthusiastic", "emoji": "๐Ÿคฉ"}, {"name": "Thoughtful", "emoji": "๐Ÿ’ญ"}
],
'instructions': [
{"name": "Create", "emoji": "๐Ÿ”จ"}, {"name": "Suggest", "emoji": "๐Ÿ’ก"},
{"name": "Write", "emoji": "โœ๏ธ"}, {"name": "Compose", "emoji": "๐Ÿ“"},
{"name": "Analyze", "emoji": "๐Ÿ”"}, {"name": "Explain", "emoji": "๐Ÿ“š"},
{"name": "Describe", "emoji": "๐Ÿ”Ž"}, {"name": "Summarize", "emoji": "๐Ÿ“‹"},
{"name": "Compare", "emoji": "โš–๏ธ"}, {"name": "Outline", "emoji": "๐Ÿ“‹"},
{"name": "Evaluate", "emoji": "โญ"}, {"name": "List", "emoji": "๐Ÿ“‹"}
],
'lengths': [
{"name": "300 Words", "emoji": "๐Ÿ“"}, {"name": "500 Words", "emoji": "๐Ÿ“„"},
{"name": "Short", "emoji": "๐Ÿฉณ"}, {"name": "Medium", "emoji": "๐Ÿ“Š"},
{"name": "Long", "emoji": "๐Ÿ“œ"}, {"name": "Brief", "emoji": "๐Ÿ’จ"},
{"name": "Detailed", "emoji": "๐Ÿ”Ž"}, {"name": "Comprehensive", "emoji": "๐Ÿ“š"}
],
'content_types': [
{"name": "Article", "emoji": "๐Ÿ“ฐ"}, {"name": "Blog post", "emoji": "๐Ÿ“"},
{"name": "Guide", "emoji": "๐Ÿ“š"}, {"name": "Email", "emoji": "๐Ÿ“ง"},
{"name": "Summary", "emoji": "๐Ÿ“‹"}, {"name": "Story", "emoji": "๐Ÿ“–"},
{"name": "Essay", "emoji": "๐Ÿ“„"}, {"name": "Review", "emoji": "โญ"},
{"name": "Tutorial", "emoji": "๐Ÿ‘จโ€๐Ÿซ"}, {"name": "Report", "emoji": "๐Ÿ“Š"},
{"name": "Plan", "emoji": "๐Ÿ“†"}, {"name": "Script", "emoji": "๐ŸŽฌ"}
],
'audiences': [
{"name": "Beginners", "emoji": "๐ŸŒฑ"}, {"name": "Experts", "emoji": "๐Ÿง "},
{"name": "Students", "emoji": "๐ŸŽ“"}, {"name": "Professionals", "emoji": "๐Ÿ‘”"},
{"name": "Business Owners", "emoji": "๐Ÿ’ผ"}, {"name": "General Public", "emoji": "๐Ÿ‘ฅ"},
{"name": "Developers", "emoji": "๐Ÿ’ป"}, {"name": "Children", "emoji": "๐Ÿ‘ถ"}
],
'formats': [
{"name": "Markdown", "emoji": "๐Ÿ“"}, {"name": "HTML", "emoji": "๐ŸŒ"},
{"name": "Plain Text", "emoji": "๐Ÿ“„"}, {"name": "JSON", "emoji": "๐Ÿ”„"},
{"name": "PDF", "emoji": "๐Ÿ“‘"}, {"name": "Python Code", "emoji": "๐Ÿ"},
{"name": "JavaScript", "emoji": "๐Ÿ“œ"}, {"name": "SQL Query", "emoji": "๐Ÿ’พ"}
]
}
# Function to create a row of buttons for a category
def create_horizontal_button_row(category_name, items, emoji_prefix=""):
st.markdown(f'<div class="category-row">', unsafe_allow_html=True)
st.markdown(f'<div class="category-label">{emoji_prefix} {category_name}:</div>', unsafe_allow_html=True)
st.markdown('<div class="horizontal-buttons">', unsafe_allow_html=True)
# Create buttons in streamlit (can't be created inside HTML)
for i, item in enumerate(items):
key = f"{category_name.lower().replace(' ', '_')}_{i}"
is_selected = st.session_state.selections.get(category_name.lower().replace(' ', '_')) == item
button_type = "primary" if is_selected else "secondary"
if st.button(f"{item['emoji']} {item['name']}", key=key,
help=f"Select {item['name']}",
type=button_type):
st.session_state.selections[category_name.lower().replace(' ', '_')] = item
st.experimental_rerun()
st.markdown('</div></div>', unsafe_allow_html=True)
# Minimal header
st.markdown("<h2 style='text-align: center; font-size: 1.2rem;'>๐Ÿง  ChatGPT Prompt Generator</h2>", unsafe_allow_html=True)
# Main layout with two columns
left_col, right_col = st.columns([3, 1])
with left_col:
# Create a horizontal row of buttons for each category
create_horizontal_button_row("Role", data['roles'], "๐Ÿ‘ค")
create_horizontal_button_row("Tone", data['tones'], "๐ŸŽญ")
create_horizontal_button_row("Instruction", data['instructions'], "๐Ÿ“")
create_horizontal_button_row("Length", data['lengths'], "๐Ÿ“")
create_horizontal_button_row("Content Type", data['content_types'], "๐Ÿ“„")
create_horizontal_button_row("Audience", data['audiences'], "๐Ÿ‘ฅ")
create_horizontal_button_row("Format", data['formats'], "๐Ÿ“‹")
# Add text inputs in a row container
st.markdown('<div class="category-row">', unsafe_allow_html=True)
st.markdown('<div class="category-label">๐Ÿ“Œ Details:</div>', unsafe_allow_html=True)
# Topic input
st.session_state.selections['about'] = st.text_input("Topic",
value=st.session_state.selections['about'],
placeholder="Enter what the content should be about",
label_visibility="collapsed")
# Two fields in one row
col1, col2 = st.columns(2)
with col1:
st.session_state.selections['inclusion'] = st.text_input("Include",
value=st.session_state.selections['inclusion'],
placeholder="What to include",
label_visibility="collapsed")
with col2:
st.session_state.selections['exclusion'] = st.text_input("Exclude",
value=st.session_state.selections['exclusion'],
placeholder="What to exclude",
label_visibility="collapsed")
# Input data
st.session_state.selections['input_data'] = st.text_area("Input Data",
value=st.session_state.selections['input_data'],
placeholder="Enter any specific information to use",
label_visibility="collapsed",
height=60)
st.markdown('</div>', unsafe_allow_html=True)
with right_col:
# Generate prompt based on selections
is_complete = all([
st.session_state.selections['role'], st.session_state.selections['tone'],
st.session_state.selections['instruction'], st.session_state.selections['length'],
st.session_state.selections['content_type'], st.session_state.selections['audience'],
st.session_state.selections['format'], st.session_state.selections['about']
])
prompt = ""
if is_complete:
sel = st.session_state.selections
prompt = f"""Act as a {sel['role']['emoji']} {sel['role']['name']}, use {sel['tone']['emoji']} {sel['tone']['name']} tone, {sel['instruction']['emoji']} {sel['instruction']['name']} a {sel['length']['emoji']} {sel['length']['name']} {sel['content_type']['emoji']} {sel['content_type']['name']} for {sel['audience']['emoji']} {sel['audience']['name']}.
It should be about {sel['about']}."""
if sel['inclusion']:
prompt += f"\nInclude {sel['inclusion']}."
if sel['exclusion']:
prompt += f"\nExclude {sel['exclusion']}."
prompt += f"\n\nReturn the output as {sel['format']['emoji']} {sel['format']['name']}."
if sel['input_data']:
prompt += f"\nUse the following information: {sel['input_data']}"
else:
prompt = "Select all required components and provide a topic."
# Display the generated prompt
st.markdown('<div class="category-row">', unsafe_allow_html=True)
st.markdown('<div class="category-label">๐Ÿ”ฎ Generated Prompt:</div>', unsafe_allow_html=True)
st.markdown('<div class="prompt-display">', unsafe_allow_html=True)
st.write(prompt)
st.markdown('</div>', unsafe_allow_html=True)
# Action buttons in a row
col1, col2, col3 = st.columns(3)
with col1:
if st.button("๐Ÿ“‹ Copy", type="primary", use_container_width=True):
st.code(prompt, language="")
with col2:
if st.button("๐Ÿ”„ Reset", type="secondary", use_container_width=True):
for key in st.session_state.selections:
if key in ['about', 'inclusion', 'exclusion', 'input_data']:
st.session_state.selections[key] = ""
else:
st.session_state.selections[key] = None
st.experimental_rerun()
with col3:
if st.button("๐ŸŽฒ Random", type="secondary", use_container_width=True):
for category in ['role', 'tone', 'instruction', 'length', 'content_type', 'audience', 'format']:
st.session_state.selections[category] = random.choice(data[category+'s'])
st.experimental_rerun()
st.markdown('</div>', unsafe_allow_html=True)
# Sample prompts and structure guide
st.markdown('<div class="category-row">', unsafe_allow_html=True)
st.markdown('<div class="category-label">๐Ÿ“š Examples:</div>', unsafe_allow_html=True)
st.markdown("""
<div style="background-color: #e6f3ff; border: 1px solid #b8daff; border-radius: 4px; padding: 4px; margin-bottom: 4px; font-size: 0.7em;">
<b>๐Ÿ‘จโ€๐Ÿซ Teaching</b><pre style="white-space: pre-wrap; font-size: 0.75em; margin: 2px 0px;">Act as a ๐Ÿ‘จโ€๐Ÿซ Teacher, use ๐Ÿ“š Informative tone, Create a ๐Ÿ“‹ Guide for ๐ŸŒฑ Beginners.
It should be about Git.
Include practical examples.
Exclude advanced techniques.
Return as ๐Ÿ“ Markdown.</pre>
</div>
<div style="background-color: #e6ffed; border: 1px solid #b8e6cc; border-radius: 4px; padding: 4px; margin-bottom: 4px; font-size: 0.7em;">
<b>๐Ÿ’ผ Business</b><pre style="white-space: pre-wrap; font-size: 0.75em; margin: 2px 0px;">Act as a ๐Ÿ‘” Professional, use ๐Ÿค Persuasive tone, Write a ๐Ÿ“ง Email for ๐Ÿ‘ฉโ€๐Ÿ’ผ Executives.
It should be about a product launch.
Include ROI metrics.
Exclude technical details.
Return as ๐Ÿ“„ Plain Text.</pre>
</div>
<div style="font-size: 0.7em; background-color: #f1f8ff; border-radius: 4px; padding: 4px; margin-top: 4px;">
<b>Structure:</b><br>
Act as [<span style="color:blue">ROLE</span>], use [<span style="color:green">TONE</span>] tone, [<span style="color:red">INSTRUCTION</span>] a [<span style="color:purple">LENGTH</span>] [<span style="color:orange">CONTENT TYPE</span>] for [<span style="color:pink">AUDIENCE</span>].<br>
It should be about [TOPIC].<br>
Include [INCLUSION]. Exclude [EXCLUSION].<br>
Return as [FORMAT].
</div>
""", unsafe_allow_html=True)
st.markdown('</div>', unsafe_allow_html=True)