Ilyas KHIAT commited on
Commit
4dc7327
1 Parent(s): 15e60f8

prompts suggestions and pdf fix

Browse files
Files changed (8) hide show
  1. .dockerignore +11 -0
  2. Dockerfile +34 -0
  3. chat_with_pps.py +53 -7
  4. export_doc.py +11 -8
  5. packages.txt +1 -16
  6. partie_prenante_carte.py +0 -5
  7. requirements.txt +0 -1
  8. temp.html +62 -13
.dockerignore ADDED
@@ -0,0 +1,11 @@
 
 
 
 
 
 
 
 
 
 
 
 
1
+ __pycache__/
2
+ *.pyc
3
+ *.pyo
4
+ *.pyd
5
+ .Python
6
+ env/
7
+ venv/
8
+ .git
9
+ .dockerignore
10
+ Dockerfile
11
+ *.md
Dockerfile ADDED
@@ -0,0 +1,34 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ # Use the official lightweight Python image.
2
+ # https://hub.docker.com/_/python
3
+ FROM python:3.9-slim
4
+
5
+ # Set environment variables
6
+ ENV PYTHONDONTWRITEBYTECODE 1
7
+ ENV PYTHONUNBUFFERED 1
8
+
9
+ # Create and set working directory
10
+ WORKDIR /app
11
+
12
+ RUN apt-get update \
13
+ && apt-get install wkhtmltopdf -y \
14
+ && mv /usr/bin/wkhtmltopdf /usr/local/bin/.
15
+
16
+ # Copy system package requirements file
17
+ COPY packages.txt .
18
+
19
+ RUN apt-get update
20
+
21
+ # Copy the application requirements file
22
+ COPY requirements.txt .
23
+
24
+ # Install Python dependencies
25
+ RUN pip install --no-cache-dir -r requirements.txt
26
+
27
+ # Copy the application code
28
+ COPY . .
29
+
30
+ # Expose the Streamlit port
31
+ EXPOSE 8501
32
+
33
+ # Run Streamlit app
34
+ CMD ["streamlit", "run", "app.py"]
chat_with_pps.py CHANGED
@@ -97,7 +97,7 @@ def format_context(partie_prenante_grouped,marque):
97
  return context
98
 
99
 
100
- def get_response(user_query, chat_history, context,llm=None):
101
 
102
  template = """
103
  Fournir des réponses, en francais, précises et contextuelles en agissant comme un expert en affaires, en utilisant le contexte des parties prenantes et leur pouvoir en pourcentage et leur influence en pourcentage pour expliquer les implications pour la marque. Le modèle doit connecter les informations du contexte et de l'historique de la conversation pour donner une réponse éclairée à la dernière question posée.
@@ -120,6 +120,20 @@ def get_response(user_query, chat_history, context,llm=None):
120
  llm = ChatMistralAI(model_name="mistral-large-latest")
121
 
122
  chain = prompt | llm | StrOutputParser()
 
 
 
 
 
 
 
 
 
 
 
 
 
 
123
 
124
  return chain.stream({
125
  "context": context,
@@ -158,14 +172,15 @@ def disp_carto_in_chat():
158
  st.rerun()
159
 
160
  @st.experimental_dialog("Télécharger",width="small")
161
- def dowmload_history():
162
  brand_name = st.session_state['Nom de la marque']
163
  format = st.radio("Choisissez le document à télécharger",[f"Rapport des parties prenantes (PDF)",f"Tableau des parties prenantes (CSV)",f"Historique de conversation (Fichier Texte)"],index=None)
164
  if format == f"Rapport des parties prenantes (PDF)":
165
  with st.spinner("Generation en cours..."):
166
  summary = get_response("Donne moi un RESUME de la Conversation", st.session_state.chat_history,format_context(st.session_state['pp_grouped'],st.session_state['Nom de la marque']),st.session_state.model)
167
  summary = ''.join(summary)
168
- pdf = export_conversation(AIMessage(content=summary).content)
 
169
  if pdf:
170
  st.download_button("Télécharger le PDF", data=pdf, file_name=f"Cartographie {brand_name}.pdf", mime="application/pdf")
171
 
@@ -213,6 +228,17 @@ def import_conversation():
213
  st.rerun()
214
  except Exception as e:
215
  st.error("Erreur lors de la lecture du fichier")
 
 
 
 
 
 
 
 
 
 
 
216
 
217
 
218
 
@@ -227,6 +253,17 @@ def display_chat():
227
  "GPT-4o":0
228
  }
229
 
 
 
 
 
 
 
 
 
 
 
 
230
  # session state
231
  if "chat_history" not in st.session_state:
232
  st.session_state.chat_history = [
@@ -236,6 +273,9 @@ def display_chat():
236
  if "model" not in st.session_state:
237
  st.session_state.model = "GPT-4o"
238
 
 
 
 
239
  #sticky bar at the top
240
  header = st.container()
241
  col1,col2,col3, col4,col5,col6 = header.columns([2,3,2,3,2,1])
@@ -248,7 +288,7 @@ def display_chat():
248
  if col3.button("Ma Carto"):
249
  disp_carto_in_chat()
250
  if col4.button("Télécharger"):
251
- dowmload_history()
252
  header.write("""<div class='fixed-header'/>""", unsafe_allow_html=True)
253
  if col5.button("Importer"):
254
  import_conversation()
@@ -293,6 +333,9 @@ def display_chat():
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,16 +353,19 @@ def display_chat():
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
 
 
97
  return context
98
 
99
 
100
+ def get_response(user_query, chat_history, context,llm=None,history_limit=5,stream=True):
101
 
102
  template = """
103
  Fournir des réponses, en francais, précises et contextuelles en agissant comme un expert en affaires, en utilisant le contexte des parties prenantes et leur pouvoir en pourcentage et leur influence en pourcentage pour expliquer les implications pour la marque. Le modèle doit connecter les informations du contexte et de l'historique de la conversation pour donner une réponse éclairée à la dernière question posée.
 
120
  llm = ChatMistralAI(model_name="mistral-large-latest")
121
 
122
  chain = prompt | llm | StrOutputParser()
123
+
124
+ if not stream:
125
+ return chain.invoke({
126
+ "context": context,
127
+ "chat_history": chat_history[-history_limit:],
128
+ "user_question": user_query,
129
+ })
130
+
131
+ if history_limit:
132
+ return chain.stream({
133
+ "context": context,
134
+ "chat_history": chat_history[-history_limit:],
135
+ "user_question": user_query,
136
+ })
137
 
138
  return chain.stream({
139
  "context": context,
 
172
  st.rerun()
173
 
174
  @st.experimental_dialog("Télécharger",width="small")
175
+ def dowmload_history(used_models=None):
176
  brand_name = st.session_state['Nom de la marque']
177
  format = st.radio("Choisissez le document à télécharger",[f"Rapport des parties prenantes (PDF)",f"Tableau des parties prenantes (CSV)",f"Historique de conversation (Fichier Texte)"],index=None)
178
  if format == f"Rapport des parties prenantes (PDF)":
179
  with st.spinner("Generation en cours..."):
180
  summary = get_response("Donne moi un RESUME de la Conversation", st.session_state.chat_history,format_context(st.session_state['pp_grouped'],st.session_state['Nom de la marque']),st.session_state.model)
181
  summary = ''.join(summary)
182
+ pdf = export_conversation(AIMessage(content=summary).content,used_models=used_models)
183
+
184
  if pdf:
185
  st.download_button("Télécharger le PDF", data=pdf, file_name=f"Cartographie {brand_name}.pdf", mime="application/pdf")
186
 
 
228
  st.rerun()
229
  except Exception as e:
230
  st.error("Erreur lors de la lecture du fichier")
231
+
232
+ def extract_format_prompts_from_response(response):
233
+ st.markdown("---\n")
234
+ prompts = response.split("\n")
235
+ prompts = [prompt.strip() for prompt in prompts if prompt.strip() != ""]
236
+ prompts_container = st.container()
237
+ with prompts_container:
238
+ for i,prompt in enumerate(prompts):
239
+ col1,col2 = st.columns([9,1])
240
+ col1.markdown(f"{prompt}")
241
+ col2.button("➡️",key=f"exec_{i}",on_click=lambda i=i: st.session_state.chat_history.append(HumanMessage(content=prompts[i])))
242
 
243
 
244
 
 
253
  "GPT-4o":0
254
  }
255
 
256
+
257
+
258
+ generated_prompt_question = '''En fonction de l'historique, proposez trois prompts pour continuer la conversation. Utilisez les informations fournies et les implications discutées:
259
+
260
+ - Prompt 1 : [Premier prompt suggéré]
261
+ - Prompt 2 : [Deuxième prompt suggéré]
262
+ - Prompt 3 : [Troisième prompt suggéré]
263
+
264
+ LA LISTE DOIT ETRE EN FRANCAIS CHAQUE LIGNE SANS LE NUMERO DE PROMPT SEULEMENT LE TEXTE DE LA QUESTION
265
+ '''
266
+
267
  # session state
268
  if "chat_history" not in st.session_state:
269
  st.session_state.chat_history = [
 
273
  if "model" not in st.session_state:
274
  st.session_state.model = "GPT-4o"
275
 
276
+ if "used_models" not in st.session_state:
277
+ st.session_state.used_models = []
278
+
279
  #sticky bar at the top
280
  header = st.container()
281
  col1,col2,col3, col4,col5,col6 = header.columns([2,3,2,3,2,1])
 
288
  if col3.button("Ma Carto"):
289
  disp_carto_in_chat()
290
  if col4.button("Télécharger"):
291
+ dowmload_history(st.session_state.used_models)
292
  header.write("""<div class='fixed-header'/>""", unsafe_allow_html=True)
293
  if col5.button("Importer"):
294
  import_conversation()
 
333
  else:
334
  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))
335
  st.session_state.chat_history.append(AIMessage(content=response))
336
+ with st.spinner("Proposition de prompts..."):
337
+ propositions_prompts = get_response(generated_prompt_question, st.session_state.chat_history,format_context(st.session_state['pp_grouped'],st.session_state['Nom de la marque']),st.session_state.model,history_limit=1,stream=False)
338
+ extract_format_prompts_from_response(propositions_prompts)
339
 
340
 
341
 
 
353
  st.markdown(user_query)
354
  with st.chat_message("AI"):
355
  st.markdown(f"**{st.session_state.model}**")
356
+ if st.session_state.model not in st.session_state.used_models:
357
+ st.session_state.used_models.append(st.session_state.model)
358
  if user_query.startswith("/rajoute"):
359
  partie_prenante = extract_pp_from_query(user_query)
360
  format_pp_add_viz(partie_prenante)
361
  disp_carto_in_chat()
362
  else:
 
363
  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))
 
 
364
  st.session_state.chat_history.append(AIMessage(content=response))
365
+ with st.spinner("Proposition de prompts..."):
366
+ propositions_prompts = get_response(generated_prompt_question, st.session_state.chat_history,format_context(st.session_state['pp_grouped'],st.session_state['Nom de la marque']),st.session_state.model,history_limit=1,stream=False)
367
+ extract_format_prompts_from_response(propositions_prompts)
368
+
369
 
370
 
371
 
export_doc.py CHANGED
@@ -9,6 +9,7 @@ from datetime import datetime
9
  from download_chart import construct_plot
10
  from kaleido.scopes.plotly import PlotlyScope
11
  import pandas as pd
 
12
 
13
  def colored_circle(color):
14
  return f'<span style="display: inline-block; width: 15px; height: 15px; border-radius: 50%; background-color: {color};"></span>'
@@ -44,14 +45,18 @@ def convert_pp_to_csv(pp_grouped):
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):
48
  # Convertir la conversation en markdown
49
  markdown_text = "\n".join([f"### {entry['speaker']}:\n {entry['text']}\n ---" for entry in conversation])
 
 
 
 
50
 
51
  markdown_summary = f"{summary}\n --- \n ---"
52
  markdown_list_pps = list_to_markdown(list_pps)
53
  # Convertir le markdown en HTML
54
- html_content = markdown2.markdown(markdown_text)
55
  html_summary = markdown2.markdown(markdown_summary)
56
  html_list_pps = markdown2.markdown(markdown_list_pps)
57
 
@@ -92,10 +97,7 @@ def create_pdf_from_markdown(logo_path, conversation,summary,brand_name,graph_ht
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>
96
- <li>(US) ChatGpt 4.o</li>
97
- <li>(FR) Mistral AI - Large (open source)</li>
98
- </ul>
99
  <img src="{logo_path}" alt="Logo" style="width: 150px;"/>
100
  </div>
101
  <div class="page-break"></div>
@@ -204,7 +206,7 @@ def get_conversation():
204
  return conversation
205
 
206
 
207
- def export_conversation(summary):
208
  brand_name = st.session_state["Nom de la marque"]
209
  app_url = "https://huggingface.co/spaces/bziiit/OpenData-Bordeaux-RSE"
210
  logo_path = "https://static.wixstatic.com/media/d7d3da_b69e03ae99224f7d8b6e358918e60071~mv2.png/v1/crop/x_173,y_0,w_1906,h_938/fill/w_242,h_119,al_c,q_85,usm_0.66_1.00_0.01,enc_auto/BZIIIT_LOGO-HORIZ-COULEUR.png" # Replace with your image path
@@ -220,9 +222,10 @@ def export_conversation(summary):
220
  st.error("Erreur lors de la génération de la cartographie")
221
  graph = ""
222
  try:
223
- pdf = create_pdf_from_markdown(logo_path=logo_path, conversation=conversation,summary=summary,brand_name=brand_name,graph_html=graph,app_url=app_url,list_pps=list_pps)
224
  except Exception as e:
225
  pdf = None
 
226
 
227
  if pdf:
228
  st.success("PDF généré avec succès!}")
 
9
  from download_chart import construct_plot
10
  from kaleido.scopes.plotly import PlotlyScope
11
  import pandas as pd
12
+ import markdown
13
 
14
  def colored_circle(color):
15
  return f'<span style="display: inline-block; width: 15px; height: 15px; border-radius: 50%; background-color: {color};"></span>'
 
45
  return pp_df.to_csv(index=True,encoding="utf-8")
46
 
47
  @st.cache_data
48
+ def create_pdf_from_markdown(logo_path, conversation,summary,brand_name,graph_html,app_url,list_pps,used_models=None):
49
  # Convertir la conversation en markdown
50
  markdown_text = "\n".join([f"### {entry['speaker']}:\n {entry['text']}\n ---" for entry in conversation])
51
+
52
+ if not used_models:
53
+ used_models = ["Aucun modèle IA n'a été utilisé"]
54
+ html_used_models = "".join([f"<p>{model}</p>" for model in used_models])
55
 
56
  markdown_summary = f"{summary}\n --- \n ---"
57
  markdown_list_pps = list_to_markdown(list_pps)
58
  # Convertir le markdown en HTML
59
+ html_content = markdown.markdown(markdown_text,extensions=['markdown.extensions.tables'])
60
  html_summary = markdown2.markdown(markdown_summary)
61
  html_list_pps = markdown2.markdown(markdown_list_pps)
62
 
 
97
  <h1>Cartographie des parties prenantes "{brand_name}"</h1>
98
  <p>Date de l'analyse IA RSE : {analysis_date}</p>
99
  <p>IA utilisées :</p>
100
+ {html_used_models}
 
 
 
101
  <img src="{logo_path}" alt="Logo" style="width: 150px;"/>
102
  </div>
103
  <div class="page-break"></div>
 
206
  return conversation
207
 
208
 
209
+ def export_conversation(summary,used_models=None):
210
  brand_name = st.session_state["Nom de la marque"]
211
  app_url = "https://huggingface.co/spaces/bziiit/OpenData-Bordeaux-RSE"
212
  logo_path = "https://static.wixstatic.com/media/d7d3da_b69e03ae99224f7d8b6e358918e60071~mv2.png/v1/crop/x_173,y_0,w_1906,h_938/fill/w_242,h_119,al_c,q_85,usm_0.66_1.00_0.01,enc_auto/BZIIIT_LOGO-HORIZ-COULEUR.png" # Replace with your image path
 
222
  st.error("Erreur lors de la génération de la cartographie")
223
  graph = ""
224
  try:
225
+ pdf = create_pdf_from_markdown(logo_path=logo_path, conversation=conversation,summary=summary,brand_name=brand_name,graph_html=graph,app_url=app_url,list_pps=list_pps,used_models=used_models)
226
  except Exception as e:
227
  pdf = None
228
+ st.error(f"{e}")
229
 
230
  if pdf:
231
  st.success("PDF généré avec succès!}")
packages.txt CHANGED
@@ -1,17 +1,2 @@
1
  wkhtmltopdf
2
- build-essential
3
- libgl1-mesa-dev
4
- xfonts-75dpi
5
- xfonts-75dpi
6
- xfonts-base
7
- gvfs
8
- colord
9
- glew-utils
10
- libvisual-0.4-plugins
11
- gstreamer1.0-tools
12
- opus-tools
13
- qt5-image-formats-plugins
14
- qtwayland5
15
- qt5-qmltooling-plugins
16
- librsvg2-bin
17
- lm-sensors
 
1
  wkhtmltopdf
2
+ xfonts-75dpi
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
partie_prenante_carte.py CHANGED
@@ -6,20 +6,15 @@ import random
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
12
  from langchain_community.vectorstores import FAISS
13
  from langchain_community.chat_models import ChatOpenAI
14
- from langchain.llms import HuggingFaceHub
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
22
- from streamlit_vertical_slider import vertical_slider
23
  from high_chart import test_chart
24
  from chat_with_pps import get_response
25
 
 
6
 
7
  import streamlit as st
8
  from dotenv import load_dotenv
 
9
  from langchain_experimental.text_splitter import SemanticChunker
10
  from langchain_community.embeddings import OpenAIEmbeddings
11
  from langchain_community.vectorstores import FAISS
12
  from langchain_community.chat_models import ChatOpenAI
 
13
  from langchain import hub
 
14
  from langchain_core.runnables import RunnablePassthrough
15
  from langchain_community.document_loaders import WebBaseLoader,FireCrawlLoader,PyPDFLoader
16
  from langchain_core.prompts.prompt import PromptTemplate
 
17
  import os
 
18
  from high_chart import test_chart
19
  from chat_with_pps import get_response
20
 
requirements.txt CHANGED
@@ -38,6 +38,5 @@ langchain-core
38
  langchain-mistralai
39
  firecrawl-py
40
  st_copy_to_clipboard
41
- pyperclip
42
  fpdf2
43
  markdown2
 
38
  langchain-mistralai
39
  firecrawl-py
40
  st_copy_to_clipboard
 
41
  fpdf2
42
  markdown2
temp.html CHANGED
@@ -3,7 +3,7 @@
3
  <html lang="en">
4
  <head>
5
  <meta charset="UTF-8">
6
- <title>Cartographie des parties prenantes bziiit</title>
7
  <link href="https://fonts.googleapis.com/css2?family=Roboto:wght@400;700&display=swap" rel="stylesheet">
8
  <style>
9
  body {
@@ -22,24 +22,23 @@
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>
30
- <li>(FR) Mistral AI - Large (open source)</li>
31
- </ul>
32
  <img src="https://static.wixstatic.com/media/d7d3da_b69e03ae99224f7d8b6e358918e60071~mv2.png/v1/crop/x_173,y_0,w_1906,h_938/fill/w_242,h_119,al_c,q_85,usm_0.66_1.00_0.01,enc_auto/BZIIIT_LOGO-HORIZ-COULEUR.png" alt="Logo" style="width: 150px;"/>
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
 
@@ -48,11 +47,61 @@
48
  <div class="page-break"></div>
49
  <h2>Historique de la Conversation</h2>
50
  <h3>AI:</h3>
51
-
52
  <p>Salut, voici votre cartographie des parties prenantes. Que puis-je faire pour vous?</p>
53
-
54
  <hr />
55
-
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
56
  </body>
57
  </html>
58
 
 
3
  <html lang="en">
4
  <head>
5
  <meta charset="UTF-8">
6
+ <title>Cartographie des parties prenantes </title>
7
  <link href="https://fonts.googleapis.com/css2?family=Roboto:wght@400;700&display=swap" rel="stylesheet">
8
  <style>
9
  body {
 
22
  </head>
23
  <body>
24
  <div style="text-align: center;">
25
+ <h1>Cartographie des parties prenantes ""</h1>
26
+ <p>Date de l'analyse IA RSE : 2024-06-27</p>
27
  <p>IA utilisées :</p>
28
+ <p>Aucun modèle IA n'a été utilisé</p>
 
 
 
29
  <img src="https://static.wixstatic.com/media/d7d3da_b69e03ae99224f7d8b6e358918e60071~mv2.png/v1/crop/x_173,y_0,w_1906,h_938/fill/w_242,h_119,al_c,q_85,usm_0.66_1.00_0.01,enc_auto/BZIIIT_LOGO-HORIZ-COULEUR.png" alt="Logo" style="width: 150px;"/>
30
  </div>
31
  <div class="page-break"></div>
32
  <div style="text-align: center; margin-top: 20px;">
33
+ <img src="">
34
  </div>
35
+ <p><span style="display: inline-block; width: 15px; height: 15px; border-radius: 50%; background-color: #80eabc;"></span> <b>bob</b>: Pouvoir:50% Influence:50%</p>
36
+
37
+ <p><span style="display: inline-block; width: 15px; height: 15px; border-radius: 50%; background-color: #43e6ed;"></span> <b>tt</b>: Pouvoir:55% Influence:50%</p>
38
 
39
  <div class="page-break"></div>
40
  <h2>RESUME</h2>
41
+ <p>Dans cette conversation, nous avons identifié et classé deux parties prenantes de la marque, Bob et TT. Chacun d'eux détient un pouvoir supérieur à 50% et une influence de 50%. En se basant sur ces critères, ils sont tous deux classés dans la catégorie "Gérer étroitement", ce qui signifie que la marque doit accorder une attention particulière à leurs attentes et besoins. Un tableau résumant ces informations a également été généré, montrant les détails de chaque partie prenante, leur pouvoir, leur influence et leur catégorie respective.</p>
42
 
43
  <hr />
44
 
 
47
  <div class="page-break"></div>
48
  <h2>Historique de la Conversation</h2>
49
  <h3>AI:</h3>
 
50
  <p>Salut, voici votre cartographie des parties prenantes. Que puis-je faire pour vous?</p>
 
51
  <hr />
52
+ <h3>Moi:</h3>
53
+ <p>/rajoute bob</p>
54
+ <hr />
55
+ <h3>AI:</h3>
56
+ <p>Partie prenante ajoutée</p>
57
+ <hr />
58
+ <h3>Moi:</h3>
59
+ <p>/rajoute tt</p>
60
+ <hr />
61
+ <h3>AI:</h3>
62
+ <p>Partie prenante ajoutée</p>
63
+ <hr />
64
+ <h3>Moi:</h3>
65
+ <p>repond en une phrase</p>
66
+ <hr />
67
+ <h3>AI:</h3>
68
+ <p>Étant donné que Bob et TT ont tous deux un pouvoir supérieur à 50% et une influence égale à 50%, ils appartiennent à la catégorie "Gérer étroitement", ce qui implique que la marque doit accorder une attention particulière à leurs attentes et besoins pour maintenir une relation positive et productive.</p>
69
+ <hr />
70
+ <h3>Moi:</h3>
71
+ <p>genere moi un tableau avec une seul ligne</p>
72
+ <hr />
73
+ <h3>AI:</h3>
74
+ <p>Voici un tableau qui résume les informations sur les parties prenantes de la marque en une seule ligne :</p>
75
+ <table>
76
+ <thead>
77
+ <tr>
78
+ <th>Partie prenante</th>
79
+ <th>Pouvoir</th>
80
+ <th>Influence</th>
81
+ <th>Catégorie</th>
82
+ </tr>
83
+ </thead>
84
+ <tbody>
85
+ <tr>
86
+ <td>Bob</td>
87
+ <td>50%</td>
88
+ <td>50%</td>
89
+ <td>Gérer étroitement</td>
90
+ </tr>
91
+ <tr>
92
+ <td>TT</td>
93
+ <td>55%</td>
94
+ <td>50%</td>
95
+ <td>Gérer étroitement</td>
96
+ </tr>
97
+ <tr>
98
+ <td>---</td>
99
+ <td></td>
100
+ <td></td>
101
+ <td></td>
102
+ </tr>
103
+ </tbody>
104
+ </table>
105
  </body>
106
  </html>
107