direct-chat.ts 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  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 DATA_KEY = 'lte.direct-chat'
  15. const EVENT_KEY = `.${DATA_KEY}`
  16. const EVENT_EXPANDED = `expanded${EVENT_KEY}`
  17. const EVENT_COLLAPSED = `collapsed${EVENT_KEY}`
  18. const SELECTOR_DATA_TOGGLE = '[data-lte-toggle="chat-pane"]'
  19. const SELECTOR_DIRECT_CHAT = '.direct-chat'
  20. const CLASS_NAME_DIRECT_CHAT_OPEN = 'direct-chat-contacts-open'
  21. /**
  22. * Class Definition
  23. * ====================================================
  24. */
  25. class DirectChat {
  26. _element: HTMLElement
  27. constructor(element: HTMLElement) {
  28. this._element = element
  29. }
  30. toggle(): void {
  31. if (this._element.classList.contains(CLASS_NAME_DIRECT_CHAT_OPEN)) {
  32. const event = new Event(EVENT_COLLAPSED)
  33. this._element.classList.remove(CLASS_NAME_DIRECT_CHAT_OPEN)
  34. this._element.dispatchEvent(event)
  35. } else {
  36. const event = new Event(EVENT_EXPANDED)
  37. this._element.classList.add(CLASS_NAME_DIRECT_CHAT_OPEN)
  38. this._element.dispatchEvent(event)
  39. }
  40. }
  41. }
  42. /**
  43. *
  44. * Data Api implementation
  45. * ====================================================
  46. */
  47. domReady(() => {
  48. const button = document.querySelectorAll(SELECTOR_DATA_TOGGLE)
  49. button.forEach(btn => {
  50. btn.addEventListener('click', event => {
  51. event.preventDefault()
  52. const target = event.target as HTMLElement
  53. const chatPane = target.closest(SELECTOR_DIRECT_CHAT) as HTMLElement | undefined
  54. if (chatPane) {
  55. const data = new DirectChat(chatPane)
  56. data.toggle()
  57. }
  58. })
  59. })
  60. })
  61. export default DirectChat