Proyectos de Subversion LeadersLinked - SPA

Rev

Rev 3295 | Rev 3297 | 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'
3295 stevensc 2
import { useMatch } from 'react-router-dom'
2477 stevensc 3
import { useSelector } from 'react-redux'
3295 stevensc 4
 
2595 stevensc 5
import 'converse.js'
6
import './converse.css'
2596 stevensc 7
import './chat.css'
5 stevensc 8
 
3201 stevensc 9
export default function Chat() {
3293 stevensc 10
  const match = useMatch('/habits/*')
11
 
3067 stevensc 12
  const {
13
    xmpp_hostname,
14
    xmpp_username,
15
    xmpp_password,
3076 stevensc 16
    xmpp_domain
17
    // xmpp_port
3067 stevensc 18
  } = useSelector((state) => state.auth)
5 stevensc 19
 
2589 stevensc 20
  useLayoutEffect(() => {
3102 stevensc 21
    const converse = window.converse
22
 
23
    if (!xmpp_hostname || !xmpp_username || !xmpp_password || !xmpp_domain) {
2595 stevensc 24
      return
3102 stevensc 25
    }
5 stevensc 26
 
2477 stevensc 27
    converse.initialize({
3076 stevensc 28
      bosh_service_url: `https://${xmpp_hostname}:${17443}/http-bind/`,
2477 stevensc 29
      authentication: 'login',
30
      jid: `${xmpp_username}@${xmpp_domain}.com`,
31
      password: xmpp_password,
32
      discover_connection_methods: false,
2480 stevensc 33
      allow_adhoc_commands: false,
2477 stevensc 34
      allow_registration: false,
2480 stevensc 35
      allow_logout: false,
2477 stevensc 36
      auto_login: true,
37
      auto_reconnect: true,
3142 stevensc 38
      debug: true,
2477 stevensc 39
      view_mode: 'overlayed',
3077 stevensc 40
      i18n: 'es',
3081 stevensc 41
      emojis: true,
3141 stevensc 42
      clear_cache_on_logout: true,
43
      persistent_store: 'localStorage',
3077 stevensc 44
      assets_path: '/public/'
2477 stevensc 45
    })
5 stevensc 46
 
2477 stevensc 47
    return () => {
2623 stevensc 48
      converse.connection?.disconnect()
5 stevensc 49
    }
3143 stevensc 50
  }, [xmpp_hostname, xmpp_password, xmpp_username])
5 stevensc 51
 
3296 stevensc 52
  console.log(match)
3293 stevensc 53
 
3296 stevensc 54
  if (match) return null
55
 
3142 stevensc 56
  return <div id='converse-container'></div>
517 stevensc 57
}