import streamlit as st
import pandas as pd
import random
import json
import os
from datetime import datetime
import base64
# Set page configuration
st.set_page_config(page_title="PromptWizardry", page_icon="đ§ ", layout="wide")
# Custom CSS for styling
st.markdown("""
""", unsafe_allow_html=True)
# Initialize session state with default topic
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': "DistillKit, MergeKit, Spectrum for ML Model Building from input Spreadsheets using torch, transformers and Streamlit",
'inclusion': "", 'exclusion': "", 'input_data': ""
}
if 'prompt_history' not in st.session_state:
st.session_state.prompt_history = []
# Data sets with emoji and names
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": "đž"},
{"name": "Image Gen Prompt", "emoji": "đŧī¸"}, {"name": "Video Gen Prompt", "emoji": "đĨ"},
{"name": "Song Gen Prompt", "emoji": "đĩ"}, {"name": "Story Gen Prompt", "emoji": "đ"}
]
}
# Function to handle selection
def handle_selection(category, item):
st.session_state.selections[category] = item
# Function to create category selection with buttons
def create_dataframe_category(category, title, emoji_prefix):
st.markdown(f"
", unsafe_allow_html=True)
st.markdown("", unsafe_allow_html=True)
cols = st.columns(4)
for i, item in enumerate(data[f"{category}s"]):
col = cols[i % 4]
label = f"{item['emoji']} {item['name']}"
is_selected = st.session_state.selections[category] == item
with col:
if st.button(label, key=f"{category}_{i}",
type="primary" if is_selected else "secondary",
use_container_width=True):
handle_selection(category, item)
st.markdown("
", unsafe_allow_html=True)
# Function to generate the final prompt
def generate_prompt():
sel = st.session_state.selections
if not all([sel['role'], sel['tone'], sel['instruction'], sel['length'],
sel['content_type'], sel['audience'], sel['format']]):
return "Please select all required components."
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']}"
return prompt
# Function to save prompt as markdown file and return filename
def save_prompt_as_md(prompt):
sel = st.session_state.selections
if not prompt.startswith("Please"):
components = [
sel['role']['name'], sel['tone']['name'], sel['instruction']['name'],
sel['length']['name'], sel['content_type']['name'], sel['audience']['name'],
sel['format']['name']
]
timestamp = datetime.now().strftime("%Y%m%d_%H%M%S")
filename = f"prompt_{'_'.join(comp.lower().replace(' ', '_') for comp in components)}_{timestamp}.md"
os.makedirs("prompts", exist_ok=True)
with open(os.path.join("prompts", filename), "w") as f:
f.write(f"```markdown\n{prompt}\n```")
return filename
return None
# Function to get list of saved .md files
def get_saved_md_files():
os.makedirs("prompts", exist_ok=True)
return [f for f in os.listdir("prompts") if f.endswith(".md")]
# Function to generate Base64 download link
def get_base64_download_link(filepath):
with open(filepath, "rb") as f:
data = f.read()
b64 = base64.b64encode(data).decode()
filename = os.path.basename(filepath)
return f'Download {filename}'
# Sidebar with Saved Prompts and Feature Outline
with st.sidebar:
st.markdown("### đ Saved Prompts")
md_files = get_saved_md_files()
if md_files:
for md_file in sorted(md_files, reverse=True):
filepath = os.path.join("prompts", md_file)
st.markdown(f"- {get_base64_download_link(filepath)}", unsafe_allow_html=True)
else:
st.write("No saved prompts yet.")
st.markdown("### đ PromptWizardry Magic")
st.markdown("""
- đ **Prompt Alchemy**: Craft with roles, tones, & more!
- đĒ **Actions**: Copy, Reset, Random, Run!
- đž **Scroll Vault**: Save & download `.md` spells!
- âŗ **Chronicles**: Relive your magic history!
- đ **Extras**: Sample spells & dazzling UI!
""")
# Header
st.markdown("⨠PromptWizardry
", unsafe_allow_html=True)
# Main layout with two columns
col1, col2 = st.columns([3, 1])
with col1:
create_dataframe_category("role", "Choose a Role", "đ¤")
create_dataframe_category("tone", "Select a Tone", "đ")
create_dataframe_category("instruction", "Select an Instruction", "đ")
create_dataframe_category("length", "Select Length", "đ")
create_dataframe_category("content_type", "Select Content Type", "đ")
create_dataframe_category("audience", "Select Target Audience", "đĨ")
create_dataframe_category("format", "Select Format", "đ")
st.markdown("", unsafe_allow_html=True)
st.markdown("", unsafe_allow_html=True)
st.session_state.selections['about'] = st.text_input("đŦ Topic",
value=st.session_state.selections['about'],
placeholder="Enter what the content should be about")
include_exclude_cols = st.columns(2)
with include_exclude_cols[0]:
st.session_state.selections['inclusion'] = st.text_input("â
Include",
value=st.session_state.selections['inclusion'],
placeholder="What to include in the content")
with include_exclude_cols[1]:
st.session_state.selections['exclusion'] = st.text_input("â Exclude",
value=st.session_state.selections['exclusion'],
placeholder="What to exclude from the content")
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",
height=100)
st.markdown("
", unsafe_allow_html=True)
with col2:
prompt = generate_prompt()
st.markdown("", unsafe_allow_html=True)
st.markdown("", unsafe_allow_html=True)
st.text_area("", value=prompt, height=150, key="generated_prompt", disabled=True,
help="Your magical prompt appears here!")
st.markdown("
", unsafe_allow_html=True)
button_cols = st.columns(4)
with button_cols[0]:
if st.button("đ Copy", type="secondary", use_container_width=True):
st.code(prompt, language="")
with button_cols[1]:
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] = "" if key != 'about' else "DistillKit, MergeKit, Spectrum for ML Model Building from input Spreadsheets using torch, transformers and Streamlit"
else:
st.session_state.selections[key] = None
st.session_state.prompt_history = []
st.rerun()
with button_cols[2]:
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.rerun()
with button_cols[3]:
if st.button("đ Run", type="primary", use_container_width=True):
if not prompt.startswith("Please"):
st.code(f"```markdown\n{prompt}\n```", language="markdown")
filename = save_prompt_as_md(prompt)
if filename:
st.success(f"Saved as {filename}")
st.session_state.prompt_history.append({
"prompt": prompt,
"timestamp": datetime.now().strftime("%Y-%m-%d %H:%M:%S"),
"filename": filename
})
st.markdown("", unsafe_allow_html=True)
st.code(f"```markdown\n{prompt}\n```", language="markdown")
st.markdown("", unsafe_allow_html=True)
st.markdown("", unsafe_allow_html=True)
st.markdown("", unsafe_allow_html=True)
if st.session_state.prompt_history:
for i, entry in enumerate(reversed(st.session_state.prompt_history)):
st.markdown(f"**Prompt {len(st.session_state.prompt_history) - i} ({entry['timestamp']})**")
st.code(f"```markdown\n{entry['prompt']}\n```", language="markdown")
st.write(f"Saved as: `{entry['filename']}`")
else:
st.write("No prompts generated yet.")
st.markdown("
", unsafe_allow_html=True)
st.markdown("", unsafe_allow_html=True)
st.markdown("", unsafe_allow_html=True)
st.markdown("""
đ¨âđĢ TeachingAct 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.
""", unsafe_allow_html=True)
st.markdown("""
đŧ BusinessAct as a đ Professional, use đ¤ Persuasive tone, Write a đ§ Email for đŧ Business Owners.
It should be about a product launch.
Include ROI metrics.
Exclude technical details.
Return as đ Plain Text.
""", unsafe_allow_html=True)
st.markdown("""
Prompt Structure:
Act as [ROLE], use [TONE] tone, [INSTRUCTION] a [LENGTH] [CONTENT TYPE] for [AUDIENCE].
It should be about [TOPIC].
Include [INCLUSION]. Exclude [EXCLUSION].
Return as [FORMAT].
""", unsafe_allow_html=True)
st.markdown("
", unsafe_allow_html=True)