Proyectos de Subversion LeadersLinked - SPA

Rev

Rev 3296 | Rev 3298 | 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
 
3297 stevensc 23
    if (
24
      !xmpp_hostname ||
25
      !xmpp_username ||
26
      !xmpp_password ||
27
      !xmpp_domain ||
28
      match
29
    ) {
2595 stevensc 30
      return
3102 stevensc 31
    }
5 stevensc 32
 
2477 stevensc 33
    converse.initialize({
3076 stevensc 34
      bosh_service_url: `https://${xmpp_hostname}:${17443}/http-bind/`,
2477 stevensc 35
      authentication: 'login',
36
      jid: `${xmpp_username}@${xmpp_domain}.com`,
37
      password: xmpp_password,
38
      discover_connection_methods: false,
2480 stevensc 39
      allow_adhoc_commands: false,
2477 stevensc 40
      allow_registration: false,
2480 stevensc 41
      allow_logout: false,
2477 stevensc 42
      auto_login: true,
43
      auto_reconnect: true,
3142 stevensc 44
      debug: true,
2477 stevensc 45
      view_mode: 'overlayed',
3077 stevensc 46
      i18n: 'es',
3081 stevensc 47
      emojis: true,
3141 stevensc 48
      clear_cache_on_logout: true,
49
      persistent_store: 'localStorage',
3077 stevensc 50
      assets_path: '/public/'
2477 stevensc 51
    })
5 stevensc 52
 
2477 stevensc 53
    return () => {
2623 stevensc 54
      converse.connection?.disconnect()
5 stevensc 55
    }
3143 stevensc 56
  }, [xmpp_hostname, xmpp_password, xmpp_username])
5 stevensc 57
 
3142 stevensc 58
  return <div id='converse-container'></div>
517 stevensc 59
}