Proyectos de Subversion LeadersLinked - SPA

Rev

Rev 3067 | Rev 3076 | Ir a la última revisión | | Comparar con el anterior | Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
2477 stevensc 1
import React, { useLayoutEffect } from 'react'
2
import { useSelector } from 'react-redux'
2595 stevensc 3
import 'converse.js'
2879 stevensc 4
 
2595 stevensc 5
import './converse.css'
2596 stevensc 6
import './chat.css'
5 stevensc 7
 
2477 stevensc 8
export function Chat() {
3067 stevensc 9
  const {
10
    xmpp_hostname,
11
    xmpp_username,
12
    xmpp_password,
13
    xmpp_domain,
14
    xmpp_port
15
  } = useSelector((state) => state.auth)
2963 stevensc 16
  const isAuth = useSelector((state) => state.auth.isAuth)
5 stevensc 17
 
2589 stevensc 18
  useLayoutEffect(() => {
2595 stevensc 19
    if (!xmpp_hostname || !xmpp_username || !xmpp_password || !xmpp_domain)
20
      return
5 stevensc 21
 
2595 stevensc 22
    const converse = window.converse
23
 
2477 stevensc 24
    converse.initialize({
3069 stevensc 25
      bosh_service_url: `https://${xmpp_hostname}:${
26
        17443 ?? xmpp_port
27
      }/http-bind/`,
2477 stevensc 28
      authentication: 'login',
29
      jid: `${xmpp_username}@${xmpp_domain}.com`,
30
      password: xmpp_password,
31
      discover_connection_methods: false,
2480 stevensc 32
      allow_adhoc_commands: false,
2477 stevensc 33
      allow_registration: false,
2480 stevensc 34
      allow_logout: false,
2477 stevensc 35
      auto_login: true,
36
      auto_reconnect: true,
37
      debug: false,
38
      view_mode: 'overlayed',
39
      i18n: 'es',
2595 stevensc 40
      assets_path: '/public/'
2477 stevensc 41
    })
5 stevensc 42
 
2477 stevensc 43
    return () => {
2623 stevensc 44
      converse.connection?.disconnect()
5 stevensc 45
    }
2589 stevensc 46
  }, [xmpp_hostname, xmpp_password, xmpp_username])
5 stevensc 47
 
2963 stevensc 48
  return isAuth ? <div id='converse-container'></div> : null
517 stevensc 49
}