Ilyas KHIAT commited on
Commit
c673bf2
·
1 Parent(s): 3befd1b

ui/ux fixes

Browse files
chat_with_pps.py CHANGED
@@ -11,6 +11,7 @@ from st_copy_to_clipboard import st_copy_to_clipboard
11
  from high_chart import test_chart
12
  from export_doc import export_conversation,convert_pp_to_csv,get_conversation
13
  import random
 
14
 
15
  def parse_conversation(file_content):
16
  conversation = []
@@ -153,7 +154,8 @@ def choose_model(index):
153
 
154
  @st.experimental_dialog("Ma cartographie",width="large")
155
  def disp_carto_in_chat():
156
- test_chart()
 
157
 
158
  @st.experimental_dialog("Télécharger",width="small")
159
  def dowmload_history():
@@ -170,7 +172,7 @@ def dowmload_history():
170
  if format == f"Tableau des parties prenantes (CSV)":
171
  csv = convert_pp_to_csv(st.session_state['pp_grouped'])
172
  if csv:
173
- st.download_button("Télécharger le CSV", data=csv, file_name=f"parties_prenantes {brand_name}.csv", mime="text/csv")
174
 
175
  if format == f"Historique de conversation (Fichier Texte)":
176
  conv = get_conversation()
@@ -184,15 +186,33 @@ def dowmload_history():
184
  if st.button("Fermer"):
185
  st.rerun()
186
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
187
  @st.experimental_dialog("Importer",width="small")
188
  def import_conversation():
189
- uploaded_file = st.file_uploader("Choisissez un fichier texte", type=["txt"])
190
  if uploaded_file is not None:
191
- file_content = uploaded_file.read()
192
- conversation = parse_conversation(file_content)
193
- message_object = convert_to_message_objects(conversation)
194
- st.session_state.chat_history.extend(message_object)
195
- st.experimental_rerun()
 
 
 
196
 
197
 
198
 
@@ -262,13 +282,17 @@ def display_chat():
262
  with st.chat_message("Moi"):
263
  st.write(message.content)
264
 
265
- #check if the last message is from the user , that means execute button has been clicked
266
  last_message = st.session_state.chat_history[-1]
267
  if isinstance(last_message, HumanMessage):
268
  with st.chat_message("AI"):
269
- response = st.write_stream(get_response(last_message.content, st.session_state.chat_history,format_context(st.session_state['pp_grouped'],st.session_state['Nom de la marque']),st.session_state.model))
270
- st_copy_to_clipboard(response)
271
- st.session_state.chat_history.append(AIMessage(content=response))
 
 
 
 
272
 
273
 
274
 
@@ -286,13 +310,16 @@ def display_chat():
286
  st.markdown(user_query)
287
  with st.chat_message("AI"):
288
  st.markdown(f"**{st.session_state.model}**")
289
- if "/rajoute" in user_query:
290
  partie_prenante = extract_pp_from_query(user_query)
291
  format_pp_add_viz(partie_prenante)
292
- response = st.write_stream(get_response(user_query, st.session_state.chat_history,format_context(st.session_state['pp_grouped'],st.session_state['Nom de la marque']),st.session_state.model))
293
- st_copy_to_clipboard(response)
294
- if "cartographie" in response:
295
- display_chart()
 
 
 
296
 
297
 
298
- st.session_state.chat_history.append(AIMessage(content=response))
 
11
  from high_chart import test_chart
12
  from export_doc import export_conversation,convert_pp_to_csv,get_conversation
13
  import random
14
+ import pandas as pd
15
 
16
  def parse_conversation(file_content):
17
  conversation = []
 
154
 
155
  @st.experimental_dialog("Ma cartographie",width="large")
156
  def disp_carto_in_chat():
157
+ if test_chart() == "saved":
158
+ st.rerun()
159
 
160
  @st.experimental_dialog("Télécharger",width="small")
161
  def dowmload_history():
 
172
  if format == f"Tableau des parties prenantes (CSV)":
173
  csv = convert_pp_to_csv(st.session_state['pp_grouped'])
174
  if csv:
175
+ st.download_button("Télécharger le CSV", data=csv, file_name=f"parties_prenantes -{brand_name}-.csv", mime="application/vnd.ms-excel")
176
 
177
  if format == f"Historique de conversation (Fichier Texte)":
178
  conv = get_conversation()
 
186
  if st.button("Fermer"):
187
  st.rerun()
188
 
189
+ def add_existing_pps(pp,pouvoir,influence):
190
+ for i in range(len(st.session_state['pp_grouped'])):
191
+ if st.session_state['pp_grouped'][i]['name'] == pp:
192
+ st.session_state['pp_grouped'][i]['x'] = influence
193
+ st.session_state['pp_grouped'][i]['y'] = pouvoir
194
+ return None
195
+ st.session_state['pp_grouped'].append({'name':pp, 'x':influence,'y':pouvoir, 'color':generate_random_color()})
196
+
197
+
198
+ def load_csv(file):
199
+ df = pd.read_csv(file)
200
+ for index, row in df.iterrows():
201
+ add_existing_pps(row['parties prenantes'],row['pouvoir'],row['influence'])
202
+
203
+
204
  @st.experimental_dialog("Importer",width="small")
205
  def import_conversation():
206
+ uploaded_file = st.file_uploader("Télécharger le fichier CSV", type="csv")
207
  if uploaded_file is not None:
208
+ file_name = uploaded_file.name
209
+ try:
210
+ load_csv(file_name)
211
+ brand_name_from_csv = file_name.split("-")[1]
212
+ st.session_state["Nom de la marque"] = brand_name_from_csv
213
+ st.rerun()
214
+ except Exception as e:
215
+ st.error("Erreur lors de la lecture du fichier")
216
 
217
 
218
 
 
282
  with st.chat_message("Moi"):
283
  st.write(message.content)
284
 
285
+ #check if the last message is from the user , that means execute button has been clicked in the prompts
286
  last_message = st.session_state.chat_history[-1]
287
  if isinstance(last_message, HumanMessage):
288
  with st.chat_message("AI"):
289
+ if last_message.content.startswith("/rajoute"):
290
+ response = "Partie prenante ajoutée"
291
+ st.write(response)
292
+ st.session_state.chat_history.append(AIMessage(content=response))
293
+ else:
294
+ response = st.write_stream(get_response(last_message.content, st.session_state.chat_history,format_context(st.session_state['pp_grouped'],st.session_state['Nom de la marque']),st.session_state.model))
295
+ st.session_state.chat_history.append(AIMessage(content=response))
296
 
297
 
298
 
 
310
  st.markdown(user_query)
311
  with st.chat_message("AI"):
312
  st.markdown(f"**{st.session_state.model}**")
313
+ if user_query.startswith("/rajoute"):
314
  partie_prenante = extract_pp_from_query(user_query)
315
  format_pp_add_viz(partie_prenante)
316
+ disp_carto_in_chat()
317
+ else:
318
+ st.warning(user_query)
319
+ response = st.write_stream(get_response(user_query, st.session_state.chat_history,format_context(st.session_state['pp_grouped'],st.session_state['Nom de la marque']),st.session_state.model))
320
+ if "cartographie" in response:
321
+ display_chart()
322
+ st.session_state.chat_history.append(AIMessage(content=response))
323
 
324
 
325
+
export_doc.py CHANGED
@@ -14,7 +14,7 @@ def colored_circle(color):
14
  return f'<span style="display: inline-block; width: 15px; height: 15px; border-radius: 50%; background-color: {color};"></span>'
15
 
16
  def list_to_markdown(lst):
17
- return "\n".join([f'<p>{colored_circle(item["color"])} {item["name"]}:</p>\ **Pouvoir**: {item["y"]}% **Influence**: {item["x"]}%' for item in lst])
18
 
19
  def categorize(row):
20
  if 50 <= row['pouvoir'] <= 100 and 0 <= row['influence'] < 50:
@@ -34,12 +34,14 @@ def convert_pp_to_csv(pp_grouped):
34
  st.error("Aucune partie prenante n'a été définie")
35
  return None
36
  pp_df = pd.DataFrame(pp_grouped)
 
37
  pp_df.rename(columns={"name": "parties prenantes", "x": "influence", "y": "pouvoir"}, inplace=True)
38
  pp_df.drop(columns=['color'], inplace=True)
39
  # Apply the function to the DataFrame to create a new column 'categorie'
40
  pp_df['categorie'] = pp_df.apply(categorize, axis=1)
41
  pp_df = pp_df[["parties prenantes","categorie", "pouvoir", "influence"]]
42
- return pp_df.to_csv().encode("utf-8")
 
43
 
44
  @st.cache_data
45
  def create_pdf_from_markdown(logo_path, conversation,summary,brand_name,graph_html,app_url,list_pps):
@@ -87,7 +89,7 @@ def create_pdf_from_markdown(logo_path, conversation,summary,brand_name,graph_ht
87
  </head>
88
  <body>
89
  <div style="text-align: center;">
90
- <h1>Cartographie des parties prenantes {brand_name}</h1>
91
  <p>Date de l'analyse IA RSE : {analysis_date}</p>
92
  <p>IA utilisées :</p>
93
  <ul>
 
14
  return f'<span style="display: inline-block; width: 15px; height: 15px; border-radius: 50%; background-color: {color};"></span>'
15
 
16
  def list_to_markdown(lst):
17
+ return "\n".join([f'<p>{colored_circle(item["color"])} <b>{item["name"]}</b>: Pouvoir:{item["y"]}% Influence:{item["x"]}%</p>' for item in lst[:20]])
18
 
19
  def categorize(row):
20
  if 50 <= row['pouvoir'] <= 100 and 0 <= row['influence'] < 50:
 
34
  st.error("Aucune partie prenante n'a été définie")
35
  return None
36
  pp_df = pd.DataFrame(pp_grouped)
37
+ pp_df.index.name = 'N°'
38
  pp_df.rename(columns={"name": "parties prenantes", "x": "influence", "y": "pouvoir"}, inplace=True)
39
  pp_df.drop(columns=['color'], inplace=True)
40
  # Apply the function to the DataFrame to create a new column 'categorie'
41
  pp_df['categorie'] = pp_df.apply(categorize, axis=1)
42
  pp_df = pp_df[["parties prenantes","categorie", "pouvoir", "influence"]]
43
+ pp_df.rename_axis('N°', axis=1)
44
+ return pp_df.to_csv(index=True,encoding="utf-8")
45
 
46
  @st.cache_data
47
  def create_pdf_from_markdown(logo_path, conversation,summary,brand_name,graph_html,app_url,list_pps):
 
89
  </head>
90
  <body>
91
  <div style="text-align: center;">
92
+ <h1>Cartographie des parties prenantes "{brand_name}"</h1>
93
  <p>Date de l'analyse IA RSE : {analysis_date}</p>
94
  <p>IA utilisées :</p>
95
  <ul>
high_chart.py CHANGED
@@ -193,16 +193,8 @@ def test_chart():
193
  # if chart:
194
  # st.session_state['pp_grouped'] = chart
195
 
196
- col0, col1, col2, col3 = st.columns([1,1,1,1])
197
 
198
  if col1.button("Sauvegarder",key="save"):
199
  st.session_state['pp_grouped'] = chart.copy()
200
- st.experimental_rerun()
201
-
202
- if col2.button("Télécharger",key="download"):
203
- if not chart:
204
- st.error("Un truc ne va pas. Veuillez réessayer")
205
- else:
206
- st.session_state['pp_grouped'] = chart.copy()
207
- fig = dc.construct_plot()
208
- st.plotly_chart(fig)
 
193
  # if chart:
194
  # st.session_state['pp_grouped'] = chart
195
 
196
+ col0,col1,col2 = st.columns([1,1,1])
197
 
198
  if col1.button("Sauvegarder",key="save"):
199
  st.session_state['pp_grouped'] = chart.copy()
200
+ return "saved"
 
 
 
 
 
 
 
 
partie_prenante_carte.py CHANGED
@@ -6,7 +6,6 @@ import random
6
 
7
  import streamlit as st
8
  from dotenv import load_dotenv
9
- from PyPDF2 import PdfReader
10
  from langchain.text_splitter import CharacterTextSplitter,RecursiveCharacterTextSplitter
11
  from langchain_experimental.text_splitter import SemanticChunker
12
  from langchain_community.embeddings import OpenAIEmbeddings
@@ -16,7 +15,7 @@ from langchain.llms import HuggingFaceHub
16
  from langchain import hub
17
  from langchain_core.output_parsers import StrOutputParser
18
  from langchain_core.runnables import RunnablePassthrough
19
- from langchain_community.document_loaders import WebBaseLoader,FireCrawlLoader
20
  from langchain_core.prompts.prompt import PromptTemplate
21
  from session import set_partie_prenante
22
  import os
@@ -131,7 +130,7 @@ def display_list_urls():
131
  delete_pp(temp)
132
  del st.session_state.urls[index]
133
  del st.session_state["parties_prenantes"][index]
134
- st.experimental_rerun() # Rerun the app to update the display
135
 
136
  if len(st.session_state.urls) > index:
137
  # Instead of using markdown, use an expander in the first column
@@ -152,7 +151,7 @@ def display_list_pps():
152
  if col2.button("❌", key=f"butp{index}"):
153
 
154
  del st.session_state["pp_grouped"][index]
155
- st.experimental_rerun()
156
 
157
  if len(st.session_state["pp_grouped"]) > index:
158
  name = st.session_state["pp_grouped"][index]["name"]
@@ -327,7 +326,7 @@ def display_pp():
327
  brand_name = st.text_input("Nom de la marque", st.session_state["Nom de la marque"])
328
  st.session_state["Nom de la marque"] = brand_name
329
 
330
- option = st.radio("Source", ("A partir de votre site web", "A partir de vos documents entreprise","A partir de fichier interieur (CSV)"))
331
 
332
  #if the user chooses to extract from website
333
  if option == "A partir de votre site web":
@@ -400,10 +399,52 @@ def display_pp():
400
 
401
  # disp_vertical_slider(partie_prenante)
402
  # st.altair_chart(c, use_container_width=True)
403
- if option == "A partir de fichier interieur (CSV)":
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
404
  uploaded_file = st.file_uploader("Télécharger le fichier CSV", type="csv")
405
  if uploaded_file is not None:
406
- load_csv(uploaded_file)
 
 
 
 
 
 
 
 
 
 
 
407
 
408
  if st.session_state["not_pp"] == "444":
409
  st.warning("Aucune parties prenantes n'est identifiable sur l'URL fournie. Fournissez une autre URL ou bien cliquez sur le boutton ci-dessous pour un Conseils IA")
 
6
 
7
  import streamlit as st
8
  from dotenv import load_dotenv
 
9
  from langchain.text_splitter import CharacterTextSplitter,RecursiveCharacterTextSplitter
10
  from langchain_experimental.text_splitter import SemanticChunker
11
  from langchain_community.embeddings import OpenAIEmbeddings
 
15
  from langchain import hub
16
  from langchain_core.output_parsers import StrOutputParser
17
  from langchain_core.runnables import RunnablePassthrough
18
+ from langchain_community.document_loaders import WebBaseLoader,FireCrawlLoader,PyPDFLoader
19
  from langchain_core.prompts.prompt import PromptTemplate
20
  from session import set_partie_prenante
21
  import os
 
130
  delete_pp(temp)
131
  del st.session_state.urls[index]
132
  del st.session_state["parties_prenantes"][index]
133
+ st.rerun() # Rerun the app to update the display
134
 
135
  if len(st.session_state.urls) > index:
136
  # Instead of using markdown, use an expander in the first column
 
151
  if col2.button("❌", key=f"butp{index}"):
152
 
153
  del st.session_state["pp_grouped"][index]
154
+ st.rerun()
155
 
156
  if len(st.session_state["pp_grouped"]) > index:
157
  name = st.session_state["pp_grouped"][index]["name"]
 
326
  brand_name = st.text_input("Nom de la marque", st.session_state["Nom de la marque"])
327
  st.session_state["Nom de la marque"] = brand_name
328
 
329
+ option = st.radio("Source", ("A partir de votre site web", "A partir de vos documents entreprise","A partir de cartographie existante"))
330
 
331
  #if the user chooses to extract from website
332
  if option == "A partir de votre site web":
 
399
 
400
  # disp_vertical_slider(partie_prenante)
401
  # st.altair_chart(c, use_container_width=True)
402
+ if option =="A partir de vos documents entreprise":
403
+
404
+ uploaded_file = st.file_uploader("Télécharger le fichier PDF", type="pdf")
405
+ if uploaded_file is not None:
406
+
407
+ if st.button("ajouter",key="add_pp_pdf"):
408
+ st.session_state["not_pp"] = ""
409
+
410
+ with st.spinner("Processing..."):
411
+ file_name = uploaded_file.name
412
+ with open(file_name, mode='wb') as w:
413
+ w.write(uploaded_file.getvalue())
414
+ pdf = PyPDFLoader(file_name)
415
+ text = pdf.load()
416
+ st.session_state["latest_doc"] = text
417
+ input_variables = {"BRAND_NAME": brand_name, "BRAND_DESCRIPTION": ""}
418
+ partie_prenante = extract_pp(text, input_variables)
419
+
420
+ if "444" in partie_prenante: #444 is the code for no brand found , chosen
421
+ st.session_state["not_pp"] = "444"
422
+
423
+ elif "445" in partie_prenante: #445 is the code for no website found with the given url
424
+ st.error("Aucun site web trouvé avec l'url donnée")
425
+ st.session_state["not_pp"] = ""
426
+
427
+ else:
428
+ st.session_state["not_pp"] = ""
429
+ partie_prenante = sorted(partie_prenante)
430
+ st.session_state["urls"].append(file_name)
431
+ add_pp(partie_prenante)
432
+
433
+ if option == "A partir de cartographie existante":
434
  uploaded_file = st.file_uploader("Télécharger le fichier CSV", type="csv")
435
  if uploaded_file is not None:
436
+ if st.button("ajouter",key="add_pp_csv"):
437
+ file_name = uploaded_file.name
438
+ with open(file_name, mode='wb') as w:
439
+ w.write(uploaded_file.getvalue())
440
+
441
+ try:
442
+ load_csv(file_name)
443
+ brand_name_from_csv = file_name.split("-")[1]
444
+ st.session_state["Nom de la marque"] = brand_name_from_csv
445
+ except Exception as e:
446
+ st.error("Erreur lors de la lecture du fichier")
447
+
448
 
449
  if st.session_state["not_pp"] == "444":
450
  st.warning("Aucune parties prenantes n'est identifiable sur l'URL fournie. Fournissez une autre URL ou bien cliquez sur le boutton ci-dessous pour un Conseils IA")
parties preanantes.csv ADDED
@@ -0,0 +1,5 @@
 
 
 
 
 
 
1
+ parties prenantes,categorie,pouvoir,influence
2
+ tt,Tenir informé,17,80
3
+ gr,Rendre satisfait,70,24
4
+ test,Gérer étroitement,55,50
5
+ boob,Gérer étroitement,77,74
parties_prenantes (10).csv ADDED
@@ -0,0 +1,2 @@
 
 
 
1
+ Col Name,parties prenantes,categorie,pouvoir,influence
2
+ 0,test,Gérer étroitement,50,50
parties_prenantes (5).csv ADDED
@@ -0,0 +1,2 @@
 
 
 
1
+ parties prenantes,categorie,pouvoir,influence
2
+ b,Gérer étroitement,50,50
parties_prenantes -bziiit-.csv ADDED
@@ -0,0 +1,2 @@
 
 
 
1
+ N°,parties prenantes,categorie,pouvoir,influence
2
+ 0,tt,Gérer étroitement,50,50
temp.html CHANGED
@@ -22,8 +22,8 @@
22
  </head>
23
  <body>
24
  <div style="text-align: center;">
25
- <h1>Cartographie des parties prenantes bziiit</h1>
26
- <p>Date de l'analyse IA RSE : 2024-06-20</p>
27
  <p>IA utilisées :</p>
28
  <ul>
29
  <li>(US) ChatGpt 4.o</li>
@@ -33,18 +33,13 @@
33
  </div>
34
  <div class="page-break"></div>
35
  <div style="text-align: center; margin-top: 20px;">
36
- <img src="">
37
  </div>
38
- <p><p><span style="display: inline-block; width: 15px; height: 15px; border-radius: 50%; background-color: #1337df;"></span> Adetem:</p> <strong>Pouvoir</strong>: 50% <strong>Influence</strong>: 50%
39
- <p><span style="display: inline-block; width: 15px; height: 15px; border-radius: 50%; background-color: #3e3365;"></span> Bordeaux technowest:</p> <strong>Pouvoir</strong>: 55% <strong>Influence</strong>: 50%
40
- <p><span style="display: inline-block; width: 15px; height: 15px; border-radius: 50%; background-color: #123a82;"></span> Digital aquitaine:</p> <strong>Pouvoir</strong>: 60% <strong>Influence</strong>: 50%
41
- <p><span style="display: inline-block; width: 15px; height: 15px; border-radius: 50%; background-color: #76318f;"></span> Hub france ia:</p> <strong>Pouvoir</strong>: 65% <strong>Influence</strong>: 50%
42
- <p><span style="display: inline-block; width: 15px; height: 15px; border-radius: 50%; background-color: #64af5e;"></span> La french tech bordeaux:</p> <strong>Pouvoir</strong>: 70% <strong>Influence</strong>: 50%
43
- <p><span style="display: inline-block; width: 15px; height: 15px; border-radius: 50%; background-color: #e9113b;"></span> Mouvement impact france:</p> <strong>Pouvoir</strong>: 75% <strong>Influence</strong>: 50%</p>
44
 
45
  <div class="page-break"></div>
46
  <h2>RESUME</h2>
47
- <p>Dans la conversation actuelle, la marque en question est bziiit. Les parties prenantes de bziiit ont été identifiées et leurs pouvoirs et influences respectifs ont été détaillés. Les six parties prenantes sont Adetem, Bordeaux Technowest, Digital Aquitaine, Hub France IA, La French Tech Bordeaux et Mouvement Impact France, chacune avec des niveaux variés de pouvoir et d'influence. Les catégories de gestion des parties prenantes ont été définies comme suit : "Rendre satisfait", "Gérer étroitement", "Suivre de près" et "Tenir informé". La question posée demandait un résumé de la conversation jusqu'à présent.</p>
48
 
49
  <hr />
50
 
 
22
  </head>
23
  <body>
24
  <div style="text-align: center;">
25
+ <h1>Cartographie des parties prenantes "bziiit"</h1>
26
+ <p>Date de l'analyse IA RSE : 2024-06-25</p>
27
  <p>IA utilisées :</p>
28
  <ul>
29
  <li>(US) ChatGpt 4.o</li>
 
33
  </div>
34
  <div class="page-break"></div>
35
  <div style="text-align: center; margin-top: 20px;">
36
+ <img src="">
37
  </div>
38
+ <p><span style="display: inline-block; width: 15px; height: 15px; border-radius: 50%; background-color: #46ca57;"></span> test - <b>Pouvoir:</b> 50% <b>Influence:</b> 50%</p>
 
 
 
 
 
39
 
40
  <div class="page-break"></div>
41
  <h2>RESUME</h2>
42
+ <p>Dans cette conversation, vous avez demandé une cartographie des parties prenantes pour la marque bziiit. Il a été identifié qu'il y a une seule partie prenante, nommée 0.test, qui possède un pouvoir de 50% et une influence de 50%. En fonction de ces paramètres, il semble que 0.test devrait être géré étroitement car leur pouvoir et leur influence sont tous deux à 50%. Ensuite, vous avez demandé un résumé de cette conversation.</p>
43
 
44
  <hr />
45