@memori.ai/memori-react 7.0.3 → 7.0.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +19 -0
- package/dist/I18nWrapper.js +7 -46
- package/dist/I18nWrapper.js.map +1 -1
- package/dist/components/ChatBubble/ChatBubble.js +0 -2
- package/dist/components/ChatBubble/ChatBubble.js.map +1 -1
- package/dist/components/ChatInputs/ChatInputs.js +2 -3
- package/dist/components/ChatInputs/ChatInputs.js.map +1 -1
- package/dist/components/ChatTextArea/ChatTextArea.css +8 -4
- package/dist/components/MemoriWidget/MemoriWidget.js +2 -6
- package/dist/components/MemoriWidget/MemoriWidget.js.map +1 -1
- package/dist/helpers/configuration.js +0 -1
- package/dist/helpers/configuration.js.map +1 -1
- package/dist/helpers/utils.d.ts +27 -0
- package/dist/helpers/utils.js +55 -1
- package/dist/helpers/utils.js.map +1 -1
- package/dist/index.js +2 -48
- package/dist/index.js.map +1 -1
- package/esm/I18nWrapper.js +7 -46
- package/esm/I18nWrapper.js.map +1 -1
- package/esm/components/ChatBubble/ChatBubble.js +0 -2
- package/esm/components/ChatBubble/ChatBubble.js.map +1 -1
- package/esm/components/ChatInputs/ChatInputs.js +2 -3
- package/esm/components/ChatInputs/ChatInputs.js.map +1 -1
- package/esm/components/ChatTextArea/ChatTextArea.css +8 -4
- package/esm/components/MemoriWidget/MemoriWidget.js +2 -6
- package/esm/components/MemoriWidget/MemoriWidget.js.map +1 -1
- package/esm/helpers/configuration.js +0 -1
- package/esm/helpers/configuration.js.map +1 -1
- package/esm/helpers/utils.d.ts +27 -0
- package/esm/helpers/utils.js +52 -0
- package/esm/helpers/utils.js.map +1 -1
- package/esm/index.js +2 -48
- package/esm/index.js.map +1 -1
- package/package.json +1 -1
- package/src/I18nWrapper.tsx +19 -58
- package/src/components/Chat/__snapshots__/Chat.test.tsx.snap +0 -253
- package/src/components/ChatBubble/ChatBubble.stories.tsx +17 -8
- package/src/components/ChatBubble/ChatBubble.test.tsx +82 -2
- package/src/components/ChatBubble/ChatBubble.tsx +2 -4
- package/src/components/ChatBubble/__snapshots__/ChatBubble.test.tsx.snap +2762 -13
- package/src/components/ChatInputs/ChatInputs.tsx +3 -5
- package/src/components/ChatInputs/__snapshots__/ChatInputs.test.tsx.snap +0 -138
- package/src/components/ChatTextArea/ChatTextArea.css +8 -4
- package/src/components/MemoriWidget/MemoriWidget.tsx +2 -9
- package/src/helpers/configuration.ts +0 -1
- package/src/helpers/utils.ts +57 -0
- package/src/index.tsx +2 -50
|
@@ -199,6 +199,38 @@ it('renders ChatBubble with markdown and breakline unchanged', () => {
|
|
|
199
199
|
expect(container).toMatchSnapshot();
|
|
200
200
|
});
|
|
201
201
|
|
|
202
|
+
it('renders ChatBubble with markdown code unchanged', () => {
|
|
203
|
+
const { container } = render(
|
|
204
|
+
<ChatBubble
|
|
205
|
+
memori={memori}
|
|
206
|
+
tenant={tenant}
|
|
207
|
+
sessionID={sessionID}
|
|
208
|
+
message={{
|
|
209
|
+
fromUser: false,
|
|
210
|
+
text: 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.\n\n```markdown\n# titolo\n```\n\nSed do eiusmod tempor incididunt ut labore et dolore magna aliqua.',
|
|
211
|
+
initial: false,
|
|
212
|
+
}}
|
|
213
|
+
/>
|
|
214
|
+
);
|
|
215
|
+
expect(container).toMatchSnapshot();
|
|
216
|
+
});
|
|
217
|
+
|
|
218
|
+
it('renders ChatBubble with markdown table unchanged', () => {
|
|
219
|
+
const { container } = render(
|
|
220
|
+
<ChatBubble
|
|
221
|
+
memori={memori}
|
|
222
|
+
tenant={tenant}
|
|
223
|
+
sessionID={sessionID}
|
|
224
|
+
message={{
|
|
225
|
+
fromUser: false,
|
|
226
|
+
text: 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.\n\n| Header 1 | Header 2 | Header 3 |\n| -------- | -------- | -------- |\n| Cell 1 | Cell 2 | Cell 3 |\n| Cell 4 | Cell 5 | Cell 6 |\n\nSed do eiusmod tempor incididunt ut labore et dolore magna aliqua.',
|
|
227
|
+
initial: false,
|
|
228
|
+
}}
|
|
229
|
+
/>
|
|
230
|
+
);
|
|
231
|
+
expect(container).toMatchSnapshot();
|
|
232
|
+
});
|
|
233
|
+
|
|
202
234
|
it('renders ChatBubble with complex markdown and math 1 unchanged', () => {
|
|
203
235
|
const { container } = render(
|
|
204
236
|
<ChatBubble
|
|
@@ -207,7 +239,7 @@ it('renders ChatBubble with complex markdown and math 1 unchanged', () => {
|
|
|
207
239
|
sessionID={sessionID}
|
|
208
240
|
message={{
|
|
209
241
|
fromUser: false,
|
|
210
|
-
text: `Per calcolare l'ipotenusa di un triangolo rettangolo, puoi usare il Teorema di Pitagora. Il teorema afferma che in un triangolo rettangolo, il quadrato dell'ipotenusa (la lato opposto all'angolo retto) è uguale alla somma dei quadrati degli altri due lati.\n\nLa formula è:\n\n\\[ c = \\sqrt{a^2 + b^2} \\]\n\nDove:\n-
|
|
242
|
+
text: `Per calcolare l'ipotenusa di un triangolo rettangolo, puoi usare il Teorema di Pitagora. Il teorema afferma che in un triangolo rettangolo, il quadrato dell'ipotenusa (la lato opposto all'angolo retto) è uguale alla somma dei quadrati degli altri due lati.\n\nLa formula è:\n\n\\[ c = \\sqrt{a^2 + b^2} \\]\n\nDove:\n- $c$ è l'ipotenusa.\n- $a$ e $ b $ sono i due cateti del triangolo.\n\n### Passaggi per il Calcolo\n\n1. **Misura o identifica i cateti $ a $ e $ b $**:\n I cateti sono i due lati che formano l'angolo retto.\n\n2. **Calcola i quadrati dei cateti**:\n Eleva al quadrato entrambe le misure dei cateti: $ a^2 $ e $ b^2 $.\n\n3. **Somma i quadrati dei cateti**:\n Somma i risultati ottenuti: $ a^2 + b^2 $.\n\n4. **Calcola la radice quadrata della somma**:\n Prendi la radice quadrata della somma per trovare l'ipotenusa: $ c = \\sqrt{a^2 + b^2} $.\n\n### Esempio di Calcolo\n\nSupponiamo di avere un triangolo rettangolo con i cateti di lunghezza 3 cm e 4 cm.\n\n1. **Cateto $ a $**: 3 cm\n2. **Cateto $ b $**: 4 cm\n\nUsiamo la formula:\n\n\\[ c = \\sqrt{a^2 + b^2} \\]\n\n\\[ c = \\sqrt{(3 \\, \\text{cm})^2 + (4 \\, \\text{cm})^2} \\]\n\n\\[ c = \\sqrt{9 \\, \\text{cm}^2 + 16 \\, \\text{cm}^2} \\]\n\n\\[ c = \\sqrt{25 \\, \\text{cm}^2} \\]\n\n\\[ c = 5 \\, \\text{cm} \\]\n\nQuindi, l'ipotenusa del triangolo è di 5 cm.`,
|
|
211
243
|
initial: false,
|
|
212
244
|
}}
|
|
213
245
|
/>
|
|
@@ -223,8 +255,56 @@ it('renders ChatBubble with complex markdown and math 2 unchanged', () => {
|
|
|
223
255
|
sessionID={sessionID}
|
|
224
256
|
message={{
|
|
225
257
|
fromUser: false,
|
|
226
|
-
text: "Per calcolare le resistenze dei materiali per le verifiche rispetto ad azioni antropiche e ambientali secondo la Specifica Tecnica ST-VAL4, si procede in questo modo:\n\n1. **Determinazione della resistenza dei materiali:**\n La resistenza dei materiali da utilizzare nelle verifiche accurate si determina a partire dalle indagini sull’opera. La caratterizzazione deve essere distinta per tutti i materiali presenti nell'opera, in accordo con la ST-PI. Le resistenze per verifiche rispetto ad azioni antropiche come i carichi da traffico e le azioni ambientali sono definite dalle LG20. Questo include la distinzione rispetto a quelle utilizzate per le azioni sismiche, come dettagliato dalle NTC18 e CIR19 .\n\n2. **Calcolo della resistenza:**\n Il valore della resistenza dei materiali
|
|
258
|
+
text: "Per calcolare le resistenze dei materiali per le verifiche rispetto ad azioni antropiche e ambientali secondo la Specifica Tecnica ST-VAL4, si procede in questo modo:\n\n1. **Determinazione della resistenza dei materiali:**\n La resistenza dei materiali da utilizzare nelle verifiche accurate si determina a partire dalle indagini sull’opera. La caratterizzazione deve essere distinta per tutti i materiali presenti nell'opera, in accordo con la ST-PI. Le resistenze per verifiche rispetto ad azioni antropiche come i carichi da traffico e le azioni ambientali sono definite dalle LG20. Questo include la distinzione rispetto a quelle utilizzate per le azioni sismiche, come dettagliato dalle NTC18 e CIR19 .\n\n2. **Calcolo della resistenza:**\n Il valore della resistenza dei materiali $ f_d $ da utilizzare nelle verifiche per carichi gravitazionali si ottiene mediante la seguente espressione:\n\n \\[\n f_d = \\min \\left( \\frac{f_m}{FC \\cdot \\gamma_M}, \\frac{f_k}{FC} \\right)\n \\]\n\n Dove:\n - $ f_m $ è il valor medio della resistenza valutato dai risultati delle prove effettuate sui campioni prelevati in situ;\n - $ f_k $ è la resistenza caratteristica calcolata sulla base dei risultati delle prove sui campioni prelevati in situ;\n - $ FC $ è il Fattore di Confidenza associato al Livello di Conoscenza raggiunto;\n - $ \\gamma_M $ è il fattore parziale di sicurezza del materiale .\n\n3. **Caratterizzazione dei materiali:**\n I valori medi, caratteristici e di progetto delle resistenze a compressione e trazione per il calcestruzzo, e delle resistenze a snervamento per l’acciaio ordinario sono determinati a partire dai risultati delle prove. Specifiche espressioni e metodi sono forniti per diversi materiali nell'Appendice 13 della ST-VAL4 .\n\n4. **Stima della resistenza da prove non distruttive:**\n Per valutare le resistenze dei materiali, si possono anche utilizzare prove non distruttive come le prove SonReb per il calcestruzzo e le prove di durezza per l'acciaio ordinario e armonico. Formulazioni specifiche per queste prove si trovano in Appendice al §13.1 della ST-VAL4 .\n\n5. **Analisi dei risultati delle indagini:**\n Gli esiti delle prove devono essere attentamente analizzati per confermare le caratteristiche originarie o rilevare eventuali decadimenti del materiale. Questo processo include anche l'identificazione delle cause di dispersione significative nei risultati delle prove .\n\nSeguendo questi passaggi, si ottiene una stima accurata delle resistenze dei materiali che possono essere utilizzate per le verifiche di sicurezza rispetto ad azioni antropiche e ambientali.",
|
|
259
|
+
initial: false,
|
|
260
|
+
}}
|
|
261
|
+
/>
|
|
262
|
+
);
|
|
263
|
+
expect(container).toMatchSnapshot();
|
|
264
|
+
});
|
|
265
|
+
|
|
266
|
+
it('renders ChatBubble with complex markdown and math 3 unchanged', () => {
|
|
267
|
+
const { container } = render(
|
|
268
|
+
<ChatBubble
|
|
269
|
+
memori={memori}
|
|
270
|
+
tenant={tenant}
|
|
271
|
+
sessionID={sessionID}
|
|
272
|
+
message={{
|
|
273
|
+
fromUser: false,
|
|
274
|
+
initial: false,
|
|
275
|
+
text: "Ok. \n\nPer calcolare l'urto su barriere metalliche, il documento *\"Ponti, viadotti e cavalcavia - Specifica Tecnica per la redazione delle Verifiche Accurate di sicurezza di Livello 4 (ST-VAL4)\"* fornisce un metodo specifico. Ecco l'iter riassunto:\n\n1. **Determinazione del sistema di forze orizzontali:** Partendo dal momento di plasticizzazione del montante (§5.1.3.10 delle NTC18). La forza orizzontale che plasticizza il montante può essere determinata con riferimento alla resistenza caratteristica degli elementi strutturali principali della barriera.\n\n2. **Quota di applicazione della forza:** La forza orizzontale deve essere applicata ad una quota h, che è il minimo tra (altezza della barriera - 0,10 m) e 1,00 m.\n\n3. **Amplificazione delle forze orizzontali:** Per il dimensionamento dell'impalcato, le forze orizzontali sono amplificate di un fattore di 1,50, e il coefficiente parziale di sicurezza per la combinazione di carico agli SLU per l’urto di veicolo in svio è assunto unitario.\n\n4. **Calcolo della massima azione tagliante:** Alla base del montante (estradosso cordolo):\n\n \\[\n F_{\\text{urto}} = \\frac{M_{\\text{pl}}}{h^*}\n \\]\n\n Dove:\n - $M_{\\text{pl}}$ è il momento plastico calcolato con la resistenza caratteristica.\n - $h^* = h - h_R - h_C$\n - $h$ è pari all’altezza della forza di urto sulla superficie di rotolamento (1.00 m), $h_B$ è l’altezza della forza rispetto all’estradosso del cordolo, $h_C$ è l’altezza del cordolo, e $h_R$ è l’altezza dell’irrigidimento del nodo e della piastra di base.\n\n5. **Determinazione del momento trasferito all’estradosso del cordolo:**\n\n \\[\n M_{\\text{urto}} = F_{\\text{urto}} \\cdot h_B = M_{\\text{pl}} \\cdot \\left(1 + \\frac{h_R}{h^*}\\right)\n \\]\n\n6. **Amplificazione per le incertezze:** Il valore caratteristico è amplificato di un fattore parziale pari a 1,50 per tenere conto delle incertezze e possibili deformabilità della lamiera irrigidita.\n\n7. **Considerazione della plasticizzazione:** Nel caso di barriere ordinarie, si considera la piena plasticizzazione di tre montanti consecutivi a seguito dell’urto, salvo diversa valutazione motivata.\n\n8. **Normative alternative:** In assenza di informazioni, si può fare riferimento al valore normativo della forza d’urto di 100 kN (NTC18) da collocarsi a 100 mm sotto la sommità dell’elemento o 1,0 m sopra il livello del piano di marcia【4:0†source】【4:1†source】【4:4†source】【4:9†source】【4:5†source】. \n\nPer ulteriori dettagli o chiarimenti, puoi consultare la sezione del documento ST-VAL4 o scrivere a anna.sganzerla@tecneautostrade.it.",
|
|
276
|
+
}}
|
|
277
|
+
/>
|
|
278
|
+
);
|
|
279
|
+
expect(container).toMatchSnapshot();
|
|
280
|
+
});
|
|
281
|
+
|
|
282
|
+
it('renders ChatBubble with complex markdown and math 4 unchanged', () => {
|
|
283
|
+
const { container } = render(
|
|
284
|
+
<ChatBubble
|
|
285
|
+
memori={memori}
|
|
286
|
+
tenant={tenant}
|
|
287
|
+
sessionID={sessionID}
|
|
288
|
+
message={{
|
|
289
|
+
fromUser: false,
|
|
290
|
+
initial: false,
|
|
291
|
+
text: "Per calcolare l'urto su barriere metalliche, è necessario considerare diversi fattori come la massa del veicolo, la velocità dell'impatto, l'angolo di impatto e le caratteristiche della barriera stessa. Di seguito è riportata una descrizione generale del processo di calcolo:\n\n1. **Determinazione dei parametri dell'urto:**\n - **Massa del veicolo (m):** La massa del veicolo che colpisce la barriera.\n - **Velocità dell'impatto (v):** La velocità del veicolo al momento dell'impatto.\n - **Angolo di impatto (θ):** L'angolo con cui il veicolo colpisce la barriera.\n\n2. **Calcolo dell'energia cinetica:**\n L'energia cinetica del veicolo al momento dell'impatto è data dalla formula:\n \\[\n E_k = \\frac{1}{2} m v^2\n \\]\n dove $E_k$ è l'energia cinetica, $m$ è la massa del veicolo e $v$ è la velocità del veicolo.\n\n3. **Calcolo della forza d'impatto:**\n La forza d'impatto può essere calcolata considerando la decelerazione del veicolo e il tempo di contatto con la barriera. Una formula semplificata per la forza d'impatto $F$ è:\n \\[\n F = \\frac{m \\Delta v}{\\Delta t}\n \\]\n dove $ \\Delta v $ è la variazione di velocità (che può essere considerata uguale alla velocità iniziale \\(v\\) se il veicolo si ferma completamente), e $ \\Delta t $ è il tempo di contatto.\n\n4. **Considerazioni sulla barriera:**\n Le barriere metalliche sono progettate per assorbire energia e ridurre la forza trasmessa ai veicoli e agli occupanti. La capacità di assorbimento dell'energia della barriera dipende dal materiale, dalla geometria e dalla costruzione della barriera stessa.\n\n5. **Normative e standard:**\n È importante seguire le normative e gli standard specifici per la progettazione e il calcolo delle barriere di sicurezza. Questi possono variare a seconda del paese e dell'applicazione specifica (ad esempio, autostrade, ponti, ecc.).\n\nPer calcoli più dettagliati e specifici, si consiglia di consultare le normative tecniche locali e di utilizzare software di simulazione specializzati che possono prendere in considerazione tutti i fattori rilevanti.",
|
|
292
|
+
}}
|
|
293
|
+
/>
|
|
294
|
+
);
|
|
295
|
+
expect(container).toMatchSnapshot();
|
|
296
|
+
});
|
|
297
|
+
|
|
298
|
+
it('renders ChatBubble with complex markdown and math 5 unchanged', () => {
|
|
299
|
+
const { container } = render(
|
|
300
|
+
<ChatBubble
|
|
301
|
+
memori={memori}
|
|
302
|
+
tenant={tenant}
|
|
303
|
+
sessionID={sessionID}
|
|
304
|
+
message={{
|
|
305
|
+
fromUser: false,
|
|
227
306
|
initial: false,
|
|
307
|
+
text: "Per calcolare l'ipotenusa di un triangolo rettangolo, puoi utilizzare il teorema di Pitagora. La formula è:\n\n\\\\[ c = \\\\sqrt{a^2 + b^2} \\\\]\n\nDove:\n- \\\\( c \\\\) è l'ipotenusa,\n- \\\\( a \\\\) e \\\\( b \\\\) sono i due cateti del triangolo.\n\nAd esempio, se hai un triangolo con i cateti di lunghezza 3 e 4, l'ipotenusa sarà:\n\n\\\\[ c = \\\\sqrt{3^2 + 4^2} = \\\\sqrt{9 + 16} = \\\\sqrt{25} = 5 \\\\]\n\nSe hai altre domande o dubbi, sono qui per aiutarti!",
|
|
228
308
|
}}
|
|
229
309
|
/>
|
|
230
310
|
);
|
|
@@ -104,8 +104,7 @@ const ChatBubble: React.FC<Props> = ({
|
|
|
104
104
|
)
|
|
105
105
|
// remove markdown multiline code blocks but keep the content
|
|
106
106
|
.replaceAll(/```markdown([^```]+)```/g, '$1')
|
|
107
|
-
|
|
108
|
-
.replaceAll(')', '\\)')
|
|
107
|
+
// remove redundant mathjax delimiters
|
|
109
108
|
.replaceAll(/(?<!\\)\(/g, '\\(')
|
|
110
109
|
.replaceAll(/(?<!\\)\)/g, '\\)')
|
|
111
110
|
) as string
|
|
@@ -118,10 +117,9 @@ const ChatBubble: React.FC<Props> = ({
|
|
|
118
117
|
ADD_ATTR: ['target'],
|
|
119
118
|
}
|
|
120
119
|
)
|
|
120
|
+
// remove redundant mathjax delimiters
|
|
121
121
|
.replaceAll(/(?<!\\)\[/g, '\\[')
|
|
122
122
|
.replaceAll(/(?<!\\)\]/g, '\\]')
|
|
123
|
-
// .replaceAll(/(?<!\\\\)\[/g, '\\\\[')
|
|
124
|
-
// .replaceAll(/(?<!\\\\)\]/g, '\\\\]')
|
|
125
123
|
// replace consecutive <br> with a single <br>
|
|
126
124
|
.replace(/(<br>)+/g, '<br>');
|
|
127
125
|
|