Proyectos de Subversion LeadersLinked - SPA

Rev

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