direct-chat.ts 1.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. /**
  2. * --------------------------------------------
  3. * AdminLTE direct-chat.ts
  4. * License MIT
  5. * --------------------------------------------
  6. */
  7. import {
  8. domReady
  9. } from './util/index'
  10. /**
  11. * Constants
  12. * ====================================================
  13. */
  14. const SELECTOR_DATA_TOGGLE = '[data-widget="chat-pane-toggle"]'
  15. const SELECTOR_DIRECT_CHAT = '.direct-chat'
  16. const CLASS_NAME_DIRECT_CHAT_OPEN = 'direct-chat-contacts-open'
  17. /**
  18. * Class Definition
  19. * ====================================================
  20. */
  21. class DirectChat {
  22. toggle(chatPane: Element): void {
  23. // chatPane
  24. chatPane.closest(SELECTOR_DIRECT_CHAT)?.classList.toggle(CLASS_NAME_DIRECT_CHAT_OPEN)
  25. }
  26. }
  27. /**
  28. *
  29. * Data Api implementation
  30. * ====================================================
  31. */
  32. domReady(() => {
  33. const button = document.querySelectorAll(SELECTOR_DATA_TOGGLE)
  34. for (const btn of button) {
  35. btn.addEventListener('click', event => {
  36. event.preventDefault()
  37. const chatPane = event.target as Element
  38. const data = new DirectChat()
  39. data.toggle(chatPane)
  40. })
  41. }
  42. })
  43. export default DirectChat