Spaces:
Sleeping
Sleeping
Ilyas KHIAT
commited on
Commit
•
4dc7327
1
Parent(s):
15e60f8
prompts suggestions and pdf fix
Browse files- .dockerignore +11 -0
- Dockerfile +34 -0
- chat_with_pps.py +53 -7
- export_doc.py +11 -8
- packages.txt +1 -16
- partie_prenante_carte.py +0 -5
- requirements.txt +0 -1
- 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 =
|
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 |
-
|
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 |
-
|
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
|
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 "
|
26 |
-
<p>Date de l'analyse IA RSE : 2024-06-
|
27 |
<p>IA utilisées :</p>
|
28 |
-
<
|
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: #
|
|
|
|
|
39 |
|
40 |
<div class="page-break"></div>
|
41 |
<h2>RESUME</h2>
|
42 |
-
<p>Dans cette conversation,
|
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 |
|