abdulllah01 commited on
Commit
e7a91a5
ยท
verified ยท
1 Parent(s): 0d40137

Update app.py

Browse files
Files changed (1) hide show
  1. app.py +89 -88
app.py CHANGED
@@ -6,55 +6,51 @@ from groq import Groq
6
  # Set up Groq client using the environment variable for API key.
7
  client = Groq(api_key=os.environ.get("GROQ_API_KEY"))
8
 
 
 
 
9
 
10
- # Speaker options
11
  speaker_options = {
12
  "Liam": "A male voice",
13
  "Dorothy": "A female voice",
14
  }
15
 
16
- # Build the Streamlit UI
17
  st.title("Conversation Script Generator Using Groq API")
18
 
 
19
  col1, col2 = st.columns(2)
20
-
21
  with col1:
22
  left_speaker = st.text_input("Left Speaker", placeholder="Enter left speaker name")
23
-
24
  with col2:
25
  right_speaker = st.text_input("Right Speaker", placeholder="Enter right speaker name")
26
 
27
- # Text area for overall conversation theme
28
  theme = st.text_area("Overall Theme of the Conversation", height=100)
29
 
30
- # Optional additional details
31
  additional_details = st.text_area("Additional Conversation Details (Optional)", height=100)
32
 
33
- # Check if all required fields are filled
34
  is_ready = bool(theme and left_speaker and right_speaker)
35
 
36
- # Disable the button if required fields are not filled
37
- if st.button("Generate Conversation", disabled=not is_ready):
38
-
39
- # Build the prompt message for Groq API.
40
- prompt = (
41
- f"""
42
- ๐Ÿ“Œ Objective
43
  Generate a highly engaging and comedic iMessage chat script formatted for video generation.
44
  The script follows a structured left-right chat format, maintains a meme-heavy, brain rot style, and incorporates sound effects, reactions, and the Cantina Roast Bot segment in a specific format.
45
-
46
  ๐Ÿ“ Script Structure & Formatting Rules
47
  1๏ธ- Contact Name (Title)
48
  At the beginning of the script, define the contact name, appearing at the top of the iMessage screen.
49
-
50
  <Contact Name>:<Contact Name>
51
  โœ… Example:
52
-
53
-
54
  Amir (expensive af delivery guy๐Ÿ†๐Ÿ’ธ):Amir (expensive af delivery guy๐Ÿ†๐Ÿ’ธ)
55
  2๏ธ- Dialogue Format
56
  Each dialogue line follows this format:
57
-
58
  <Direction>: <SpeakerName> > <Phrase 1> <Phrase 2> <Phrase 3> <Phrase 4> [Reaction]
59
  Left: Represents the left speaker (User).
60
  Right: Represents the right speaker (Other character).
@@ -62,52 +58,36 @@ SpeakerName: A randomly assigned name, but characters do not know their own name
62
  Phrase Limit: Max 4 phrases per line.
63
  Reaction Cues: Placed at the end of lines, enclosed in square brackets [].
64
  โœ… Example:
65
-
66
-
67
  Left: Unknown Guy> Bro what is this? This is not food [shocked]
68
- Right: Amir > My guy that's a gourmet dish ๐Ÿคจ [suspense_music]
69
  Left: Unknown Guy> Gourmet?? Itโ€™s literally burnt [explosion]
70
- Right: Amir > Charcoal adds flavor, trust me bro ๐Ÿ˜Ž
71
  3๏ธ- Bracketed Cues & Sound Effects
72
  Use brackets [ ] for sound effects, reactions, or video cues.
73
-
74
  [shocked] โ†’ Must be used often
75
  [fart2] โ†’ Should be used less
76
  [fortnite] โ†’ Should be used less
77
  [get_out] โ†’ Must ONLY be used at the end of the conversation
78
  โœ… Example:
79
-
80
- sql
81
- Copy
82
- Edit
83
  Right: Amir> BRO WHY IS THERE A RAT IN MY BURGER?!! [shocked] ๐Ÿ€๐Ÿ”
84
  Left: Unknown Guy> Extra protein sir ๐Ÿ˜Ž
85
  Right: Amir> ๐Ÿ’€๐Ÿ’€๐Ÿ’€ [fortnite]
86
  4๏ธ- Image Placeholders
87
  For inserting images, use:
88
-
89
- php-template
90
- Copy
91
- Edit
92
  <Direction>: img:<DescriptiveImageName>
93
  โœ… Example:
94
-
95
-
96
  Left: img:burnt_food_delivery
97
  Right: Amir> BRO WHY IS MY PIZZA LOOKING LIKE CHARCOAL?!! [shocked]
98
  Min. 3 images per script.
99
  Descriptive placeholders must be clear.
100
  5๏ธ- Cantina App (Roast Bot Segment)
101
  ๐Ÿšจ Correct Format (ALWAYS THE SAME STRUCTURE)
102
-
103
  Right speaker initiates by opening Cantina.
104
  Right speaker asks Roast Bot for help.
105
  Left speaker (ALWAYS Antoni) responds.
106
  Right speaker must repeat what Roast Bot told them to say.
107
  Contact Name Title must reappear after Cantina.
108
  โœ… Correct Example:
109
-
110
-
111
  Cantina: Roast bot:Roast bot pfp == Alex> Let me open the cantina app to talk to Roast bot
112
  Right: Alex> Hey Roast Bot
113
  Right: Alex> Amir is mad at me for not wanting to tip him
@@ -118,16 +98,12 @@ Left: Antoni> maybe you should start working for real and not begging for tips a
118
  Amir (expensive af delivery guy๐Ÿ†๐Ÿ’ธ):Amir (expensive af delivery guy๐Ÿ†๐Ÿ’ธ)
119
  Right: Alex> maybe you should start working for real and not begging for tips all the time
120
  ๐Ÿ”น Rules:
121
-
122
  Right speaker MUST repeat the roast word-for-word.
123
  The contact name/title must reappear after the Cantina segment.
124
  DO NOT GIVE HEADING TO SEGMENTS, all the script should be in one flow and should be at least 30 messages long
125
  6๏ธโƒฃ Brain Rot Hook (MANDATORY)
126
  Every script must begin with an insane, wacky brain rot hook that immediately grabs attention.
127
-
128
  โœ… Examples:
129
-
130
- =
131
  "๐Ÿšจ BRO I JUST ORDERED UBER EATS AND THIS GUY SHOWED UP IN A SPACESHIP???" ๐Ÿš€๐Ÿ‘€
132
  "WHY DID MY DAD JUST SAY HE WANTS TO PLAY GTA WITH ME???" ๐ŸŽฎ๐Ÿ’€
133
  "SIR WHY IS MY LAWYER ALSO MY UBER DRIVER?!" ๐Ÿ‘จโ€โš–๐Ÿš—๐Ÿ’จ
@@ -135,12 +111,10 @@ Must be over-the-top and chaotic.
135
  Encourages immediate engagement.
136
  7๏ธ- Escalation & Progression
137
  The story must escalate into chaos but stay coherent:
138
-
139
  Start Crazy โ†’ Get Crazier โ†’ End With a Punchline or Twist
140
  Use sudden twists and reveals to maintain engagement.
141
  The final line should be either a funny resolution or an abrupt exit.
142
  โœ… Example Progression:
143
-
144
  ๐Ÿš€ Crazy Hook:
145
  "BRO WHY IS MY PIZZA DELIVERY GUY ALSO MY LAWYER???" ๐Ÿ•๐Ÿ‘จโ€โš–
146
  ๐Ÿ”ฅ Escalation:
@@ -152,60 +126,87 @@ The final line should be either a funny resolution or an abrupt exit.
152
  ๐Ÿƒโ€โ™‚๏ธ Dramatic Exit (ALWAYS USE [get_out])
153
  "Left: Lawyer> I quit. [get_out]"
154
  DO NOT USE THESE NAMES IN CONTACT OR IN TEXTS, THESE ARE ONLY TO TELL THE PROGRAM WHICH VOICE TO USE
155
- Left Actor={left_speaker}
156
- Right Actor={right_speaker}
157
- Theme={theme}
158
  """
159
- )
160
- if additional_details.strip():
161
- prompt += f"Additional Details: {additional_details}\n"
162
 
163
-
 
 
 
164
 
165
- # Prepare the message payload for the Groq API call.
166
- messages = [
167
- {
168
- "role": "user",
169
- "content": prompt,
170
- }
171
- ]
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
172
 
173
- # Model selection: adjust as needed.
 
 
174
 
175
- model = "llama-3.3-70b-versatile"
176
-
177
  try:
178
- # Make the chat completion call using Groq.
179
  chat_completion = client.chat.completions.create(
180
- messages=messages,
181
  model=model,
182
  temperature=1.2,
183
  max_completion_tokens=21890,
184
-
185
-
186
  )
187
-
188
- # Extract the generated conversation from the API response.
189
- result_text = chat_completion.choices[0].message.content
190
-
191
- if not result_text:
192
- st.error("The API call did not return any content.")
193
- else:
194
- st.success("Conversation generated successfully!")
195
-
196
- # Display the result inside a text area.
197
- st.write("### Generated Conversation Script")
198
- st.text_area("", result_text, height=300)
199
-
200
- # Create a downloadable TXT file.
201
- txt_bytes = result_text.encode("utf-8")
202
- txt_io = io.BytesIO(txt_bytes)
203
- st.download_button(
204
- label="Download Script as TXT",
205
- data=txt_io,
206
- file_name="conversation_script.txt",
207
- mime="text/plain"
208
- )
209
-
210
  except Exception as e:
211
- st.error(f"An error occurred while calling the API: {e}")
 
 
 
 
6
  # Set up Groq client using the environment variable for API key.
7
  client = Groq(api_key=os.environ.get("GROQ_API_KEY"))
8
 
9
+ # Initialize session state for chat history if it doesn't exist.
10
+ if "chat_history" not in st.session_state:
11
+ st.session_state.chat_history = [] # Each entry: {"role": "user"/"assistant", "content": "..."}
12
 
13
+ # Speaker options (unused in chat but kept for reference)
14
  speaker_options = {
15
  "Liam": "A male voice",
16
  "Dorothy": "A female voice",
17
  }
18
 
19
+ # Build the Streamlit UI header.
20
  st.title("Conversation Script Generator Using Groq API")
21
 
22
+ # Create columns for left/right speaker inputs.
23
  col1, col2 = st.columns(2)
 
24
  with col1:
25
  left_speaker = st.text_input("Left Speaker", placeholder="Enter left speaker name")
 
26
  with col2:
27
  right_speaker = st.text_input("Right Speaker", placeholder="Enter right speaker name")
28
 
29
+ # Text area for overall conversation theme.
30
  theme = st.text_area("Overall Theme of the Conversation", height=100)
31
 
32
+ # Optional additional details.
33
  additional_details = st.text_area("Additional Conversation Details (Optional)", height=100)
34
 
35
+ # Determine if required fields are filled.
36
  is_ready = bool(theme and left_speaker and right_speaker)
37
 
38
+ # Container for initial conversation generation.
39
+ with st.container():
40
+ if st.button("Generate Conversation", disabled=not is_ready):
41
+ # Build the initial prompt.
42
+ prompt = f"""
43
+ ๐Ÿ“Œ Objective
 
44
  Generate a highly engaging and comedic iMessage chat script formatted for video generation.
45
  The script follows a structured left-right chat format, maintains a meme-heavy, brain rot style, and incorporates sound effects, reactions, and the Cantina Roast Bot segment in a specific format.
 
46
  ๐Ÿ“ Script Structure & Formatting Rules
47
  1๏ธ- Contact Name (Title)
48
  At the beginning of the script, define the contact name, appearing at the top of the iMessage screen.
 
49
  <Contact Name>:<Contact Name>
50
  โœ… Example:
 
 
51
  Amir (expensive af delivery guy๐Ÿ†๐Ÿ’ธ):Amir (expensive af delivery guy๐Ÿ†๐Ÿ’ธ)
52
  2๏ธ- Dialogue Format
53
  Each dialogue line follows this format:
 
54
  <Direction>: <SpeakerName> > <Phrase 1> <Phrase 2> <Phrase 3> <Phrase 4> [Reaction]
55
  Left: Represents the left speaker (User).
56
  Right: Represents the right speaker (Other character).
 
58
  Phrase Limit: Max 4 phrases per line.
59
  Reaction Cues: Placed at the end of lines, enclosed in square brackets [].
60
  โœ… Example:
 
 
61
  Left: Unknown Guy> Bro what is this? This is not food [shocked]
62
+ Right: Amir> My guy that's a gourmet dish ๐Ÿคจ [suspense_music]
63
  Left: Unknown Guy> Gourmet?? Itโ€™s literally burnt [explosion]
64
+ Right: Amir> Charcoal adds flavor, trust me bro ๐Ÿ˜Ž
65
  3๏ธ- Bracketed Cues & Sound Effects
66
  Use brackets [ ] for sound effects, reactions, or video cues.
 
67
  [shocked] โ†’ Must be used often
68
  [fart2] โ†’ Should be used less
69
  [fortnite] โ†’ Should be used less
70
  [get_out] โ†’ Must ONLY be used at the end of the conversation
71
  โœ… Example:
 
 
 
 
72
  Right: Amir> BRO WHY IS THERE A RAT IN MY BURGER?!! [shocked] ๐Ÿ€๐Ÿ”
73
  Left: Unknown Guy> Extra protein sir ๐Ÿ˜Ž
74
  Right: Amir> ๐Ÿ’€๐Ÿ’€๐Ÿ’€ [fortnite]
75
  4๏ธ- Image Placeholders
76
  For inserting images, use:
 
 
 
 
77
  <Direction>: img:<DescriptiveImageName>
78
  โœ… Example:
 
 
79
  Left: img:burnt_food_delivery
80
  Right: Amir> BRO WHY IS MY PIZZA LOOKING LIKE CHARCOAL?!! [shocked]
81
  Min. 3 images per script.
82
  Descriptive placeholders must be clear.
83
  5๏ธ- Cantina App (Roast Bot Segment)
84
  ๐Ÿšจ Correct Format (ALWAYS THE SAME STRUCTURE)
 
85
  Right speaker initiates by opening Cantina.
86
  Right speaker asks Roast Bot for help.
87
  Left speaker (ALWAYS Antoni) responds.
88
  Right speaker must repeat what Roast Bot told them to say.
89
  Contact Name Title must reappear after Cantina.
90
  โœ… Correct Example:
 
 
91
  Cantina: Roast bot:Roast bot pfp == Alex> Let me open the cantina app to talk to Roast bot
92
  Right: Alex> Hey Roast Bot
93
  Right: Alex> Amir is mad at me for not wanting to tip him
 
98
  Amir (expensive af delivery guy๐Ÿ†๐Ÿ’ธ):Amir (expensive af delivery guy๐Ÿ†๐Ÿ’ธ)
99
  Right: Alex> maybe you should start working for real and not begging for tips all the time
100
  ๐Ÿ”น Rules:
 
101
  Right speaker MUST repeat the roast word-for-word.
102
  The contact name/title must reappear after the Cantina segment.
103
  DO NOT GIVE HEADING TO SEGMENTS, all the script should be in one flow and should be at least 30 messages long
104
  6๏ธโƒฃ Brain Rot Hook (MANDATORY)
105
  Every script must begin with an insane, wacky brain rot hook that immediately grabs attention.
 
106
  โœ… Examples:
 
 
107
  "๐Ÿšจ BRO I JUST ORDERED UBER EATS AND THIS GUY SHOWED UP IN A SPACESHIP???" ๐Ÿš€๐Ÿ‘€
108
  "WHY DID MY DAD JUST SAY HE WANTS TO PLAY GTA WITH ME???" ๐ŸŽฎ๐Ÿ’€
109
  "SIR WHY IS MY LAWYER ALSO MY UBER DRIVER?!" ๐Ÿ‘จโ€โš–๐Ÿš—๐Ÿ’จ
 
111
  Encourages immediate engagement.
112
  7๏ธ- Escalation & Progression
113
  The story must escalate into chaos but stay coherent:
 
114
  Start Crazy โ†’ Get Crazier โ†’ End With a Punchline or Twist
115
  Use sudden twists and reveals to maintain engagement.
116
  The final line should be either a funny resolution or an abrupt exit.
117
  โœ… Example Progression:
 
118
  ๐Ÿš€ Crazy Hook:
119
  "BRO WHY IS MY PIZZA DELIVERY GUY ALSO MY LAWYER???" ๐Ÿ•๐Ÿ‘จโ€โš–
120
  ๐Ÿ”ฅ Escalation:
 
126
  ๐Ÿƒโ€โ™‚๏ธ Dramatic Exit (ALWAYS USE [get_out])
127
  "Left: Lawyer> I quit. [get_out]"
128
  DO NOT USE THESE NAMES IN CONTACT OR IN TEXTS, THESE ARE ONLY TO TELL THE PROGRAM WHICH VOICE TO USE
129
+ Left Actor = {left_speaker}
130
+ Right Actor = {right_speaker}
131
+ Theme = {theme}
132
  """
133
+ if additional_details.strip():
134
+ prompt += f"\nAdditional Details: {additional_details}\n"
 
135
 
136
+ # Start the conversation history with the initial prompt.
137
+ st.session_state.chat_history = [{"role": "user", "content": prompt}]
138
+
139
+ model = "llama-3.3-70b-versatile"
140
 
141
+ try:
142
+ chat_completion = client.chat.completions.create(
143
+ messages=st.session_state.chat_history,
144
+ model=model,
145
+ temperature=1.2,
146
+ max_completion_tokens=21890,
147
+ )
148
+
149
+ result_text = chat_completion.choices[0].message.content
150
+
151
+ if not result_text:
152
+ st.error("The API call did not return any content.")
153
+ else:
154
+ st.success("Conversation generated successfully!")
155
+ # Append the generated conversation to chat history.
156
+ st.session_state.chat_history.append({"role": "assistant", "content": result_text})
157
+
158
+ # Display the generated conversation.
159
+ st.write("### Generated Conversation Script")
160
+ st.text_area("", result_text, height=300)
161
+
162
+ # Offer a download of the script.
163
+ txt_bytes = result_text.encode("utf-8")
164
+ txt_io = io.BytesIO(txt_bytes)
165
+ st.download_button(
166
+ label="Download Script as TXT",
167
+ data=txt_io,
168
+ file_name="conversation_script.txt",
169
+ mime="text/plain"
170
+ )
171
+ except Exception as e:
172
+ st.error(f"An error occurred while calling the API: {e}")
173
+
174
+ # ------------------------------------------------------------------
175
+ # Chat Interface Section
176
+ # This section will appear after the initial generation (or if history already exists)
177
+ st.markdown("---")
178
+ st.header("Chat & Modify Conversation Script")
179
+
180
+ # Display the chat history.
181
+ for msg in st.session_state.chat_history:
182
+ if msg["role"] == "user":
183
+ st.markdown(f"**User:** {msg['content']}")
184
+ else:
185
+ st.markdown(f"**Assistant:** {msg['content']}")
186
+
187
+ # Form to send a new chat message.
188
+ with st.form(key="chat_form", clear_on_submit=True):
189
+ user_message = st.text_area("Enter your message (e.g., request modifications)", height=100)
190
+ submit_chat = st.form_submit_button("Send")
191
 
192
+ if submit_chat and user_message.strip():
193
+ # Append the new user message to chat history.
194
+ st.session_state.chat_history.append({"role": "user", "content": user_message})
195
 
196
+ # Call the Groq API with the entire conversation history to keep memory intact.
 
197
  try:
198
+ model = "llama-3.3-70b-versatile"
199
  chat_completion = client.chat.completions.create(
200
+ messages=st.session_state.chat_history,
201
  model=model,
202
  temperature=1.2,
203
  max_completion_tokens=21890,
 
 
204
  )
205
+ reply = chat_completion.choices[0].message.content
206
+ st.session_state.chat_history.append({"role": "assistant", "content": reply})
207
+ st.success("Response received!")
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
208
  except Exception as e:
209
+ st.error(f"An error occurred while calling the API: {e}")
210
+
211
+ # Refresh the chat display.
212
+ st.experimental_rerun()