zignal-stencil-library 1.1.120 → 1.1.121

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (270) hide show
  1. package/dist/cjs/autocomplete-address_43.cjs.entry.js +193 -110
  2. package/dist/cjs/loader.cjs.js +1 -1
  3. package/dist/cjs/quick-message-app.cjs.entry.js +2 -2
  4. package/dist/cjs/quick-message-app.entry.cjs.js.map +1 -1
  5. package/dist/cjs/zignal-stencil-library.cjs.js +1 -1
  6. package/dist/collection/components/autocomplete-address/autocomplete-address.css +1 -1
  7. package/dist/collection/components/autocomplete-multiple-select/autocomplete-multiple-select.css +1 -1
  8. package/dist/collection/components/autocomplete-select/autocomplete-select.css +1 -1
  9. package/dist/collection/components/autocomplete-select/autocomplete-select.js +51 -8
  10. package/dist/collection/components/autocomplete-select/autocomplete-select.js.map +1 -1
  11. package/dist/collection/components/channel-box/channel-box.css +1 -1
  12. package/dist/collection/components/channel-box/channel-box.js +2 -2
  13. package/dist/collection/components/channel-box/channel-box.js.map +1 -1
  14. package/dist/collection/components/chat-app/chat-app.css +1 -1
  15. package/dist/collection/components/chat-app/chat-app.js +1 -1
  16. package/dist/collection/components/chat-header/chat-header.css +1 -1
  17. package/dist/collection/components/chat-header/chat-header.js +2 -1
  18. package/dist/collection/components/chat-header/chat-header.js.map +1 -1
  19. package/dist/collection/components/chat-input/chat-input.css +1 -1
  20. package/dist/collection/components/checkbox-list/checkbox-list.css +1 -1
  21. package/dist/collection/components/checkbox-list/checkbox-list.js +1 -1
  22. package/dist/collection/components/dialog-bill-editor/dialog-bill-editor.css +1 -1
  23. package/dist/collection/components/dialog-bill-editor/dialog-bill-editor.js +3 -3
  24. package/dist/collection/components/dialog-editor/dialog-editor.css +1 -1
  25. package/dist/collection/components/dialog-editor/dialog-editor.js +1 -1
  26. package/dist/collection/components/dialog-preview-media/dialog-preview-media.css +1 -1
  27. package/dist/collection/components/dialog-preview-media/dialog-preview-media.js +1 -1
  28. package/dist/collection/components/dialog-search/dialog-search.css +1 -1
  29. package/dist/collection/components/dialog-search/dialog-search.js +2 -2
  30. package/dist/collection/components/internal-component/about-section.js +3 -2
  31. package/dist/collection/components/internal-component/about-section.js.map +1 -1
  32. package/dist/collection/components/internal-component/chat-item.js +2 -1
  33. package/dist/collection/components/internal-component/chat-item.js.map +1 -1
  34. package/dist/collection/components/internal-component/context-section.js +6 -6
  35. package/dist/collection/components/internal-component/context-section.js.map +1 -1
  36. package/dist/collection/components/internal-component/z-avatar-group.js +44 -0
  37. package/dist/collection/components/internal-component/z-avatar-group.js.map +1 -0
  38. package/dist/collection/components/internal-component/z-context-input.js +34 -1
  39. package/dist/collection/components/internal-component/z-context-input.js.map +1 -1
  40. package/dist/collection/components/menu-chat-channel/menu-chat-channel.css +1 -1
  41. package/dist/collection/components/menu-chat-channel/menu-chat-channel.js +2 -2
  42. package/dist/collection/components/menu-chat-type/menu-chat-type.css +1 -1
  43. package/dist/collection/components/menu-chat-type/menu-chat-type.js +2 -2
  44. package/dist/collection/components/menu-list/menu-list.css +1 -1
  45. package/dist/collection/components/menu-list/menu-list.js +2 -2
  46. package/dist/collection/components/message-box/message-box.css +1 -1
  47. package/dist/collection/components/message-box/message-box.js +8 -8
  48. package/dist/collection/components/message-box/message-box.js.map +1 -1
  49. package/dist/collection/components/message-content/message-content.css +1 -1
  50. package/dist/collection/components/message-content/message-content.js +1 -1
  51. package/dist/collection/components/message-item/message-item.css +1 -1
  52. package/dist/collection/components/message-item/message-item.js +1 -1
  53. package/dist/collection/components/message-item/message-item.js.map +1 -1
  54. package/dist/collection/components/message-media/message-media.css +1 -1
  55. package/dist/collection/components/message-media/message-media.js +2 -2
  56. package/dist/collection/components/profile-history/profile-history.css +1 -1
  57. package/dist/collection/components/profile-history/profile-history.js +1 -1
  58. package/dist/collection/components/profile-info/profile-info.css +1 -1
  59. package/dist/collection/components/profile-info/profile-info.js +3 -4
  60. package/dist/collection/components/profile-info/profile-info.js.map +1 -1
  61. package/dist/collection/components/profile-info/user-info-section.js +5 -4
  62. package/dist/collection/components/profile-info/user-info-section.js.map +1 -1
  63. package/dist/collection/components/profile-media/profile-media.css +1 -1
  64. package/dist/collection/components/profile-media/profile-media.js +1 -1
  65. package/dist/collection/components/profile-tabs/profile-tabs.css +1 -1
  66. package/dist/collection/components/profile-tabs/profile-tabs.js +2 -2
  67. package/dist/collection/components/quick-message-add-template/quick-message-add-template.css +1 -1
  68. package/dist/collection/components/quick-message-add-template/quick-message-add-template.js +3 -3
  69. package/dist/collection/components/quick-message-add-template/quick-message-text-content.js +1 -1
  70. package/dist/collection/components/quick-message-app/quick-message-app.css +1 -1
  71. package/dist/collection/components/quick-message-app/quick-message-app.js +1 -1
  72. package/dist/collection/components/quick-message-file/quick-message-file.css +1 -1
  73. package/dist/collection/components/quick-message-file/quick-message-file.js +1 -1
  74. package/dist/collection/components/quick-message-image/quick-message-image.css +1 -1
  75. package/dist/collection/components/quick-message-image/quick-message-image.js +1 -1
  76. package/dist/collection/components/quick-message-modal/quick-message-modal.css +1 -1
  77. package/dist/collection/components/quick-message-modal/quick-message-modal.js +1 -1
  78. package/dist/collection/components/quick-message-template/quick-message-template.css +1 -1
  79. package/dist/collection/components/quick-message-template/quick-message-template.js +2 -2
  80. package/dist/collection/components/search-box/search-box.css +1 -1
  81. package/dist/collection/components/search-box/search-box.js +1 -1
  82. package/dist/collection/components/status-badge/status-badge.css +1 -1
  83. package/dist/collection/components/status-badge/status-badge.js +2 -2
  84. package/dist/collection/components/tag-list/tag-list.css +1 -1
  85. package/dist/collection/components/tag-list/tag-list.js +1 -1
  86. package/dist/collection/components/tag-or-status-item/tag-or-status-item.css +1 -1
  87. package/dist/collection/components/tag-or-status-item/tag-or-status-item.js +3 -3
  88. package/dist/collection/components/tag-popper/tag-popper.css +1 -1
  89. package/dist/collection/components/tag-popper/tag-popper.js +2 -2
  90. package/dist/collection/components/typography-clamp/typography-clamp.css +1 -1
  91. package/dist/collection/components/typography-clamp/typography-clamp.js +2 -2
  92. package/dist/collection/components/z-avatar/z-avatar.css +1 -1
  93. package/dist/collection/components/z-dialog/z-dialog.css +1 -1
  94. package/dist/collection/store/type.js.map +1 -1
  95. package/dist/components/autocomplete-address.js +1 -1
  96. package/dist/components/autocomplete-multiple-select.js +1 -1
  97. package/dist/components/autocomplete-select.js +1 -1
  98. package/dist/components/channel-box.js +1 -1
  99. package/dist/components/chat-app.js +40 -40
  100. package/dist/components/chat-app.js.map +1 -1
  101. package/dist/components/chat-header.js +1 -1
  102. package/dist/components/chat-input.js +1 -1
  103. package/dist/components/checkbox-list.js +1 -1
  104. package/dist/components/dialog-bill-editor.js +1 -1
  105. package/dist/components/dialog-editor.js +1 -1
  106. package/dist/components/dialog-preview-media.js +1 -1
  107. package/dist/components/dialog-search.js +1 -1
  108. package/dist/components/menu-chat-channel.js +1 -1
  109. package/dist/components/menu-chat-type.js +1 -1
  110. package/dist/components/menu-list.js +1 -1
  111. package/dist/components/message-box.js +1 -1
  112. package/dist/components/message-content.js +1 -1
  113. package/dist/components/message-item.js +1 -1
  114. package/dist/components/message-media.js +1 -1
  115. package/dist/components/p-1nKZsYJV.js +184 -0
  116. package/dist/components/{p-CUj1nhQz.js.map → p-1nKZsYJV.js.map} +1 -1
  117. package/dist/components/{p-DMd05Um5.js → p-4ednqCu1.js} +4 -4
  118. package/dist/components/{p-DMd05Um5.js.map → p-4ednqCu1.js.map} +1 -1
  119. package/dist/components/{p-BvDuogVa.js → p-8qEzh9SS.js} +3 -3
  120. package/dist/components/{p-BvDuogVa.js.map → p-8qEzh9SS.js.map} +1 -1
  121. package/dist/components/p-B3vYYgfy.js +142 -0
  122. package/dist/components/{p-BdL8rT5_.js.map → p-B3vYYgfy.js.map} +1 -1
  123. package/dist/components/p-B6Oqalkt.js +161 -0
  124. package/dist/components/{p-Cm5Tu5hu.js.map → p-B6Oqalkt.js.map} +1 -1
  125. package/dist/components/{p-BkBWf1Cy.js → p-BOcFErqH.js} +10 -10
  126. package/dist/components/{p-BkBWf1Cy.js.map → p-BOcFErqH.js.map} +1 -1
  127. package/dist/components/p-BR0qHxMx.js +219 -0
  128. package/dist/components/{p-Di6mdDHT.js.map → p-BR0qHxMx.js.map} +1 -1
  129. package/dist/components/p-Bgn09v-w.js +124 -0
  130. package/dist/components/p-Bgn09v-w.js.map +1 -0
  131. package/dist/components/p-Bk5H61H8.js +49 -0
  132. package/dist/components/p-Bk5H61H8.js.map +1 -0
  133. package/dist/components/p-BksE5hg7.js +235 -0
  134. package/dist/components/{p-DL0DzsFZ.js.map → p-BksE5hg7.js.map} +1 -1
  135. package/dist/components/p-BoydN4os.js +112 -0
  136. package/dist/components/{p-CmM_sMR_.js.map → p-BoydN4os.js.map} +1 -1
  137. package/dist/components/{p-Btv5yGUC.js → p-BzI2D97S.js} +7 -7
  138. package/dist/components/{p-Btv5yGUC.js.map → p-BzI2D97S.js.map} +1 -1
  139. package/dist/components/p-CArvTJoW.js +35 -0
  140. package/dist/components/{p-C6m7w9NI.js.map → p-CArvTJoW.js.map} +1 -1
  141. package/dist/components/p-CCNzvfR_.js +159 -0
  142. package/dist/components/p-CCNzvfR_.js.map +1 -0
  143. package/dist/components/p-CNiD6fCD.js +61 -0
  144. package/dist/components/{p-IA-aLtLv.js.map → p-CNiD6fCD.js.map} +1 -1
  145. package/dist/components/p-CQVxpQMS.js +144 -0
  146. package/dist/components/{p-DAJw-tbK.js.map → p-CQVxpQMS.js.map} +1 -1
  147. package/dist/components/{p-DWGG12d7.js → p-C_-YDF9v.js} +23 -23
  148. package/dist/components/p-C_-YDF9v.js.map +1 -0
  149. package/dist/components/p-CbGFIm5U.js +111 -0
  150. package/dist/components/{p-DdsdwO_H.js.map → p-CbGFIm5U.js.map} +1 -1
  151. package/dist/components/p-CgauTkVI.js +190 -0
  152. package/dist/components/p-CgauTkVI.js.map +1 -0
  153. package/dist/components/p-Csghi5Jh.js +79 -0
  154. package/dist/components/{p-31br2kMO.js.map → p-Csghi5Jh.js.map} +1 -1
  155. package/dist/components/p-CyqxQQZN.js +140 -0
  156. package/dist/components/{p-B8wFfwyb.js.map → p-CyqxQQZN.js.map} +1 -1
  157. package/dist/components/p-D04d-ugd.js +160 -0
  158. package/dist/components/{p-7iAEgUyO.js.map → p-D04d-ugd.js.map} +1 -1
  159. package/dist/components/p-D0p9pya8.js +137 -0
  160. package/dist/components/{p-Ban2D5qJ.js.map → p-D0p9pya8.js.map} +1 -1
  161. package/dist/components/p-D2VXWXdE.js +101 -0
  162. package/dist/components/{p-CUYo1ORi.js.map → p-D2VXWXdE.js.map} +1 -1
  163. package/dist/components/{p-s_BTBIS6.js → p-D7CoDfLl.js} +4 -4
  164. package/dist/components/{p-s_BTBIS6.js.map → p-D7CoDfLl.js.map} +1 -1
  165. package/dist/components/p-D9jyxDSc.js +113 -0
  166. package/dist/components/{p-CDwHujQ4.js.map → p-D9jyxDSc.js.map} +1 -1
  167. package/dist/components/p-DGIY0GDJ.js +178 -0
  168. package/dist/components/p-DGIY0GDJ.js.map +1 -0
  169. package/dist/components/p-D_IHjZ-q.js +163 -0
  170. package/dist/components/{p-r6Y-THRS.js.map → p-D_IHjZ-q.js.map} +1 -1
  171. package/dist/components/{p-D-dRi6vp.js → p-DqJdsfJb.js} +9 -9
  172. package/dist/components/{p-D-dRi6vp.js.map → p-DqJdsfJb.js.map} +1 -1
  173. package/dist/components/{p-ByvcFo5l.js → p-DtaKGAKx.js} +27 -27
  174. package/dist/components/p-DtaKGAKx.js.map +1 -0
  175. package/dist/components/p-I30--9yD.js +124 -0
  176. package/dist/components/{p-C80JRP_Z.js.map → p-I30--9yD.js.map} +1 -1
  177. package/dist/components/p-Qu1JlZOI.js +81 -0
  178. package/dist/components/{p-Cdb_mDW6.js.map → p-Qu1JlZOI.js.map} +1 -1
  179. package/dist/components/p-VGL-Lt1l.js +132 -0
  180. package/dist/components/{p-NKykWBHc.js.map → p-VGL-Lt1l.js.map} +1 -1
  181. package/dist/components/p-Xe33--ik.js +55 -0
  182. package/dist/components/{p-CSmkuoKg.js.map → p-Xe33--ik.js.map} +1 -1
  183. package/dist/components/p-fhCpNNOm.js +126 -0
  184. package/dist/components/{p-wStqtX3x.js.map → p-fhCpNNOm.js.map} +1 -1
  185. package/dist/components/p-jorn7g2f.js +107 -0
  186. package/dist/components/{p-DCyptOYB.js.map → p-jorn7g2f.js.map} +1 -1
  187. package/dist/components/p-mDwRdOtm.js +315 -0
  188. package/dist/components/p-mDwRdOtm.js.map +1 -0
  189. package/dist/components/p-sJKH7vtI.js +104 -0
  190. package/dist/components/{p-DfOWzuNH.js.map → p-sJKH7vtI.js.map} +1 -1
  191. package/dist/components/p-yzEW8ucQ.js +227 -0
  192. package/dist/components/{p-UVgIcMzN.js.map → p-yzEW8ucQ.js.map} +1 -1
  193. package/dist/components/profile-history.js +1 -1
  194. package/dist/components/profile-info.js +1 -1
  195. package/dist/components/profile-media.js +1 -1
  196. package/dist/components/profile-tabs.js +1 -1
  197. package/dist/components/quick-message-add-template.js +1 -1
  198. package/dist/components/quick-message-app.js +8 -8
  199. package/dist/components/quick-message-app.js.map +1 -1
  200. package/dist/components/quick-message-file.js +1 -1
  201. package/dist/components/quick-message-image.js +1 -1
  202. package/dist/components/quick-message-modal.js +1 -1
  203. package/dist/components/quick-message-template.js +1 -1
  204. package/dist/components/quick-message-text-content.js +1 -1
  205. package/dist/components/search-box.js +1 -1
  206. package/dist/components/status-badge.js +1 -1
  207. package/dist/components/summarize-message-section.js +1 -1
  208. package/dist/components/tag-list.js +1 -1
  209. package/dist/components/tag-or-status-item.js +1 -1
  210. package/dist/components/tag-popper.js +1 -1
  211. package/dist/components/typography-clamp.js +1 -1
  212. package/dist/components/user-info-section.js +1 -1
  213. package/dist/components/z-avatar.js +1 -1
  214. package/dist/components/z-dialog.js +1 -1
  215. package/dist/esm/autocomplete-address_43.entry.js +193 -110
  216. package/dist/esm/loader.js +1 -1
  217. package/dist/esm/quick-message-app.entry.js +2 -2
  218. package/dist/esm/quick-message-app.entry.js.map +1 -1
  219. package/dist/esm/zignal-stencil-library.js +1 -1
  220. package/dist/types/components/autocomplete-select/autocomplete-select.d.ts +3 -0
  221. package/dist/types/components/internal-component/z-avatar-group.d.ts +6 -0
  222. package/dist/types/components/internal-component/z-context-input.d.ts +0 -1
  223. package/dist/types/components.d.ts +10 -0
  224. package/dist/types/store/type.d.ts +2 -2
  225. package/dist/zignal-stencil-library/{p-64501dea.entry.js → p-6e8b1e6b.entry.js} +3 -3
  226. package/dist/zignal-stencil-library/p-6e8b1e6b.entry.js.map +1 -0
  227. package/dist/zignal-stencil-library/p-bf2b0918.entry.js +2 -0
  228. package/dist/zignal-stencil-library/{p-5dc50b92.entry.js.map → p-bf2b0918.entry.js.map} +1 -1
  229. package/dist/zignal-stencil-library/quick-message-app.entry.esm.js.map +1 -1
  230. package/dist/zignal-stencil-library/zignal-stencil-library.esm.js +1 -1
  231. package/package.json +1 -1
  232. package/dist/components/p-31br2kMO.js +0 -79
  233. package/dist/components/p-7iAEgUyO.js +0 -160
  234. package/dist/components/p-B8wFfwyb.js +0 -140
  235. package/dist/components/p-BPlLefeT.js +0 -189
  236. package/dist/components/p-BPlLefeT.js.map +0 -1
  237. package/dist/components/p-Ban2D5qJ.js +0 -137
  238. package/dist/components/p-BdL8rT5_.js +0 -142
  239. package/dist/components/p-ByvcFo5l.js.map +0 -1
  240. package/dist/components/p-C6m7w9NI.js +0 -35
  241. package/dist/components/p-C80JRP_Z.js +0 -124
  242. package/dist/components/p-CDwHujQ4.js +0 -113
  243. package/dist/components/p-CNMTDTD6.js +0 -126
  244. package/dist/components/p-CNMTDTD6.js.map +0 -1
  245. package/dist/components/p-CSmkuoKg.js +0 -55
  246. package/dist/components/p-CUYo1ORi.js +0 -101
  247. package/dist/components/p-CUj1nhQz.js +0 -184
  248. package/dist/components/p-Cdb_mDW6.js +0 -81
  249. package/dist/components/p-Ch2unUs4.js +0 -123
  250. package/dist/components/p-Ch2unUs4.js.map +0 -1
  251. package/dist/components/p-Cm5Tu5hu.js +0 -161
  252. package/dist/components/p-CmM_sMR_.js +0 -112
  253. package/dist/components/p-DAJw-tbK.js +0 -144
  254. package/dist/components/p-DCyptOYB.js +0 -107
  255. package/dist/components/p-DL0DzsFZ.js +0 -235
  256. package/dist/components/p-DTo4lyq1.js +0 -168
  257. package/dist/components/p-DTo4lyq1.js.map +0 -1
  258. package/dist/components/p-DWGG12d7.js.map +0 -1
  259. package/dist/components/p-DWTuyVHk.js +0 -314
  260. package/dist/components/p-DWTuyVHk.js.map +0 -1
  261. package/dist/components/p-DdsdwO_H.js +0 -111
  262. package/dist/components/p-DfOWzuNH.js +0 -104
  263. package/dist/components/p-Di6mdDHT.js +0 -219
  264. package/dist/components/p-IA-aLtLv.js +0 -61
  265. package/dist/components/p-NKykWBHc.js +0 -132
  266. package/dist/components/p-UVgIcMzN.js +0 -227
  267. package/dist/components/p-r6Y-THRS.js +0 -163
  268. package/dist/components/p-wStqtX3x.js +0 -126
  269. package/dist/zignal-stencil-library/p-5dc50b92.entry.js +0 -2
  270. package/dist/zignal-stencil-library/p-64501dea.entry.js.map +0 -1
@@ -1,314 +0,0 @@
1
- import { h, p as proxyCustomElement, H, a as Host } from './p-DRz4sc4i.js';
2
- import { c as configStore, s as selectedChatStore, u as userStore, r as responsiveStore, p as profilePanelStore, a as chatsStore } from './p-C-yg0vtE.js';
3
- import { Z as ZIconButton } from './p-CXREPMwB.js';
4
- import { k as syncMessage, l as syncTags, u as updateChat, m as updateUser } from './p-J_olRnMz.js';
5
- import { l as leaveRoom } from './p-rEwMLqpC.js';
6
- import { f as serviceReadMessage, i as serviceUnReadMessage } from './p-hhz0UGz2.js';
7
- import { i as isUnread, b as getChatPicture, g as getChatName, d as getChatChannelPictureUrl } from './p-svoisvoB.js';
8
- import { h as handleError } from './p-DS28c-yX.js';
9
- import { I as Icon } from './p-BhidTUJs.js';
10
- import { d as defineCustomElement$2 } from './p-C80JRP_Z.js';
11
- import { d as defineCustomElement$1 } from './p-CUYo1ORi.js';
12
-
13
- const ZButtonGroup = ({ id, options, value, onChange, size = 'medium', fullWidth = false, variant = 'primary', }) => {
14
- const theme = configStore.get('theme');
15
- let sizeClass = 'z-button-group-medium';
16
- if (size === 'small') {
17
- sizeClass = 'z-button-group-small';
18
- }
19
- if (size === 'large') {
20
- sizeClass = 'z-button-group-large';
21
- }
22
- const handleButtonClick = (optionValue, disabled) => {
23
- if (!disabled && onChange) {
24
- onChange(optionValue);
25
- }
26
- };
27
- return (h("div", { id: id, class: `z-button-group ${variant === 'tab' ? 'z-button-group-tab' : ''} ${sizeClass} ${fullWidth ? 'w-full' : ''}`, style: variant === 'tab'
28
- ? { backgroundColor: theme === 'light' ? 'rgba(0,0,0,0.3)' : 'rgba(255,255,255,0.3)' }
29
- : {} }, options.map((option, index) => {
30
- const isSelected = value === option.value;
31
- const isDisabled = option.disabled || false;
32
- const isFirst = index === 0;
33
- const isLast = index === options.length - 1;
34
- let buttonClass = 'z-button-group-item';
35
- if (variant === 'tab') {
36
- buttonClass += ' z-button-group-item-tab';
37
- if (isSelected) {
38
- buttonClass += ' z-button-group-item-tab-selected';
39
- }
40
- else {
41
- buttonClass += ' z-button-group-item-tab-unselected';
42
- }
43
- }
44
- else {
45
- if (isFirst) {
46
- buttonClass += ' z-button-group-item-first';
47
- }
48
- if (isLast) {
49
- buttonClass += ' z-button-group-item-last';
50
- }
51
- if (!isFirst && !isLast) {
52
- buttonClass += ' z-button-group-item-middle';
53
- }
54
- if (variant === 'primary') {
55
- if (isSelected) {
56
- buttonClass += ' z-button-group-item-primary-selected';
57
- }
58
- else {
59
- buttonClass += ' z-button-group-item-primary-unselected';
60
- }
61
- }
62
- else {
63
- if (isSelected) {
64
- buttonClass += ' z-button-group-item-outlined-selected';
65
- }
66
- else {
67
- buttonClass += ' z-button-group-item-outlined-unselected';
68
- }
69
- }
70
- }
71
- if (isDisabled) {
72
- buttonClass += ' z-button-group-item-disabled';
73
- }
74
- buttonClass += ` ${sizeClass}`;
75
- return (h("button", { key: option.value, type: "button", class: buttonClass, disabled: isDisabled, onClick: () => handleButtonClick(option.value, isDisabled) }, option.label));
76
- })));
77
- };
78
-
79
- const chatHeaderCss = "@layer base{*,::backdrop,:after,:before{--tw-space-y-reverse:0;--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-space-x-reverse:0;--tw-shadow:0 0 #0000;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-alpha:100%;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-offset-width:0;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-drop-shadow-alpha:100%;--tw-border-style:solid;border:0 solid;box-sizing:border-box;margin:0;padding:0}}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-space-x-reverse:0;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-font-weight:initial;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-border-style:solid;--tw-space-y-reverse:0;--tw-leading:initial;--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0}}}@layer theme{:host,:root{--container-xl:36rem;--color-yellow-500:oklch(79.5% .184 86.047);--container-3xs:16rem;--container-sm:24rem;--color-yellow-300:oklch(90.5% .182 98.111);--color-red-50:oklch(97.1% .013 17.38);--color-red-200:oklch(88.5% .062 18.334);--color-slate-100:oklch(96.8% .007 247.896);--color-slate-200:oklch(92.9% .013 255.508);--color-slate-700:oklch(37.2% .044 257.287);--color-slate-900:oklch(20.8% .042 265.755);--container-xs:20rem;--container-md:28rem;--text-2xl:1.5rem;--text-2xl--line-height:1.33333;--color-slate-500:oklch(55.4% .046 257.417);--leading-tight:1.25;--leading-snug:1.375;--leading-relaxed:1.625;--color-red-700:oklch(50.5% .213 27.518);--color-green-700:oklch(52.7% .154 150.069);--color-pink-100:oklch(94.8% .028 342.258);--font-weight-bold:700;--animate-spin:spin 1s linear infinite;--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,\"Liberation Mono\",\"Courier New\",monospace;--color-red-500:oklch(63.7% .237 25.331);--color-green-500:oklch(72.3% .219 149.579);--color-blue-500:oklch(62.3% .214 259.815);--color-blue-600:oklch(54.6% .245 262.881);--color-gray-100:oklch(96.7% .003 264.542);--color-gray-200:oklch(92.8% .006 264.531);--color-gray-300:oklch(87.2% .01 258.338);--color-gray-400:oklch(70.7% .022 261.325);--color-gray-500:oklch(55.1% .027 264.364);--color-gray-600:oklch(44.6% .03 256.802);--color-gray-700:oklch(37.3% .034 259.733);--color-black:#000;--color-white:#fff;--spacing:.25rem;--text-xs:.75rem;--text-xs--line-height:1.33333;--text-sm:.875rem;--text-sm--line-height:1.42857;--text-base:1rem;--text-base--line-height:1.5;--text-lg:1.125rem;--text-lg--line-height:1.55556;--font-weight-medium:500;--font-weight-semibold:600;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--radius-3xl:1.5rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:\"Kanit\",var(--default-font);--default-mono-font-family:var(--font-mono);--default-font:ui-sans-serif,system-ui,sans-serif,\"Apple Color Emoji\",\"Segoe UI Emoji\",\"Segoe UI Symbol\",\"Noto Color Emoji\";--color-primary:#e02848;--color-secondary:#023761;--color-background:#fff;--color-primary-dark:#b50f30;--color-secondary-dark:#fff;--color-background-dark:#23292d}}@layer base{::file-selector-button{appearance:button;background-color:#0000;border:0 solid;border-radius:0;box-sizing:border-box;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;margin:0;margin-inline-end:4px;opacity:1;padding:0}:host,html{-webkit-text-size-adjust:100%;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,\"Apple Color Emoji\",\"Segoe UI Emoji\",\"Segoe UI Symbol\",\"Noto Color Emoji\");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);tab-size:4;-webkit-tap-highlight-color:transparent;line-height:1.5}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,\"Liberation Mono\",\"Courier New\",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-size:1em;font-variation-settings:var(--default-mono-font-variation-settings,normal)}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}button,input,optgroup,select,textarea{background-color:#0000;border-radius:0;color:inherit;font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;opacity:1}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;min-height:1.5em;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit,::-webkit-datetime-edit-year-field{padding-block:0;padding-bottom:0;padding-top:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-month-field{padding-block:0;padding-bottom:0;padding-top:0}::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field{padding-block:0;padding-bottom:0;padding-top:0}::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-second-field{padding-block:0;padding-bottom:0;padding-top:0}::-webkit-datetime-edit-meridiem-field{padding-block:0;padding-bottom:0;padding-top:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}[multiple],[type=date],[type=datetime-local],[type=email],[type=month],[type=number],[type=password],[type=search],[type=tel],[type=text],[type=time],[type=url],[type=week],input:where(:not([type])),select,textarea{appearance:none;--tw-shadow:0 0 #0000;background-color:#fff;border-color:oklch(55.1% .027 264.364);border-radius:0;border-width:1px;font-size:1rem;line-height:1.5rem;padding:.5rem .75rem}:is([type=text],input:where(:not([type])),[type=email],[type=url],[type=password],[type=number],[type=date],[type=datetime-local],[type=month],[type=search],[type=tel],[type=time],[type=week],[multiple],textarea,select):focus{outline-offset:2px;--tw-ring-inset:var(--tw-empty, );--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:oklch(54.6% .245 262.881);--tw-ring-offset-shadow:var(--tw-ring-inset)0 0 0 var(--tw-ring-offset-width)var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset)0 0 0 calc(1px + var(--tw-ring-offset-width))var(--tw-ring-color);border-color:oklch(54.6% .245 262.881);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow);outline:2px solid #0000}input::placeholder,textarea::placeholder{color:oklch(55.1% .027 264.364);opacity:1}::-webkit-datetime-edit-fields-wrapper{padding:0}select{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='oklch(55.1%25 0.027 264.364)' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E\");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem;print-color-adjust:exact}[multiple],[size]:where(select:not([size=\"1\"])){background-image:none;background-position:0 0;background-repeat:unset;background-size:initial;padding-right:.75rem;print-color-adjust:unset}[type=checkbox],[type=radio]{appearance:none;color:oklch(54.6% .245 262.881);print-color-adjust:exact;-webkit-user-select:none;user-select:none;vertical-align:middle;--tw-shadow:0 0 #0000;background-color:#fff;background-origin:border-box;border-color:oklch(55.1% .027 264.364);border-width:1px;display:inline-block;flex-shrink:0;height:1rem;padding:0;width:1rem}[type=checkbox]{border-radius:0}[type=radio]{border-radius:100%}[type=checkbox]:focus,[type=radio]:focus{outline-offset:2px;--tw-ring-inset:var(--tw-empty, );--tw-ring-offset-width:2px;--tw-ring-offset-color:#fff;--tw-ring-color:oklch(54.6% .245 262.881);--tw-ring-offset-shadow:var(--tw-ring-inset)0 0 0 var(--tw-ring-offset-width)var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset)0 0 0 calc(2px + var(--tw-ring-offset-width))var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow);outline:2px solid #0000}[type=checkbox]:checked,[type=radio]:checked{background-color:currentColor;background-position:50%;background-repeat:no-repeat;background-size:100% 100%;border-color:#0000}[type=checkbox]:checked{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 16 16'%3E%3Cpath d='M12.207 4.793a1 1 0 0 1 0 1.414l-5 5a1 1 0 0 1-1.414 0l-2-2a1 1 0 0 1 1.414-1.414L6.5 9.086l4.293-4.293a1 1 0 0 1 1.414 0'/%3E%3C/svg%3E\")}[type=radio]:checked{background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='%23fff' viewBox='0 0 16 16'%3E%3Ccircle cx='8' cy='8' r='3'/%3E%3C/svg%3E\")}[type=checkbox]:checked:focus,[type=checkbox]:checked:hover,[type=radio]:checked:focus,[type=radio]:checked:hover{background-color:currentColor;border-color:#0000}[type=checkbox]:indeterminate{background-color:currentColor;background-image:url(\"data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 16 16'%3E%3Cpath stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 8h8'/%3E%3C/svg%3E\");background-position:50%;background-repeat:no-repeat;background-size:100% 100%;border-color:#0000}[type=checkbox]:indeterminate:focus,[type=checkbox]:indeterminate:hover{background-color:currentColor;border-color:#0000}[type=file]{background:unset;border-color:inherit;border-radius:0;border-width:0;font-size:unset;line-height:inherit;padding:0}[type=file]:focus{outline:1px solid buttontext;outline:1px auto -webkit-focus-ring-color}}@layer components{.dialog-backdrop{align-items:center;background-color:#0006;display:flex;inset:calc(var(--spacing)*0);justify-content:center;position:fixed;z-index:50}@supports (color:color-mix(in lab,red,red)){.dialog-backdrop{background-color:color-mix(in oklab,var(--color-black)40%,transparent);background-color:color-mix(in srgb,#00040%,transparent)}}.chat-item{border-radius:var(--radius-xl);cursor:pointer;margin-block:calc(var(--spacing)*1);margin-inline:calc(var(--spacing)*2);padding-block:calc(var(--spacing)*3);padding-inline:calc(var(--spacing)*4);--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);align-items:flex-start;box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow);display:flex;position:relative}:where(.chat-item>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-end:calc(var(--spacing)*4*(1 - var(--tw-space-x-reverse)));margin-inline-start:calc(var(--spacing)*4*var(--tw-space-x-reverse))}.chat-item .chat-item-pin{position:absolute;right:calc(var(--spacing)*-3);top:calc(var(--spacing)*1)}.chat-item .chat-item-pin-icon{fill:currentColor;height:calc(var(--spacing)*3);rotate:45deg;width:calc(var(--spacing)*3)}.chat-item .chat-item-content-container{display:flex;flex-direction:row;width:100%}:where(.chat-item .chat-item-content-container>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-end:calc(var(--spacing)*4*(1 - var(--tw-space-x-reverse)));margin-inline-start:calc(var(--spacing)*4*var(--tw-space-x-reverse))}.chat-item .chat-item-avatar-wrapper{align-self:center;flex-shrink:0;position:relative}.chat-item .chat-item-avatar-badge{bottom:calc(var(--spacing)*-.5);position:absolute;right:calc(var(--spacing)*-.5)}.chat-item .chat-item-content-wrapper{min-height:calc(var(--spacing)*18);width:100%}.chat-item .chat-item-content-main{align-items:center;display:flex}:where(.chat-item .chat-item-content-main>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-end:calc(var(--spacing)*1*(1 - var(--tw-space-x-reverse)));margin-inline-start:calc(var(--spacing)*1*var(--tw-space-x-reverse))}.chat-item .chat-item-content-main-image{border-radius:3.40282e+38px;height:calc(var(--spacing)*4);width:calc(var(--spacing)*4)}.chat-item .chat-item-content-main-name{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.chat-item .chat-item-content-main-name,.chat-item .chat-item-content-main-time{-webkit-line-clamp:1;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.chat-item .chat-item-content-main-time{color:var(--color-gray-500);font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height));margin-left:auto}.chat-item .chat-item-content-secondary{align-items:flex-start;display:flex;flex-direction:row;width:100%}.chat-item .chat-item-content-secondary-nickname{font-size:var(--text-base);-webkit-line-clamp:1;line-height:var(--tw-leading,var(--text-base--line-height));-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.chat-item .chat-item-content-secondary-message{color:var(--color-gray-600);font-size:var(--text-sm);-webkit-line-clamp:1;line-height:var(--tw-leading,var(--text-sm--line-height));-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.chat-item .chat-item-content-unread{background-color:var(--color-primary);border-radius:3.40282e+38px;color:var(--color-white);font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height));margin-left:auto}.chat-item .chat-item-content-unread-mark{display:inline-block;height:calc(var(--spacing)*2.5);width:calc(var(--spacing)*2.5)}.chat-item .chat-item-content-unread-count{padding-block:calc(var(--spacing)*.5);padding-inline:calc(var(--spacing)*2)}.z-icon-button{cursor:pointer;font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));--tw-font-weight:var(--font-weight-medium);align-items:center;border-radius:3.40282e+38px;display:inline-flex;font-weight:var(--font-weight-medium);justify-content:center;transition-duration:var(--tw-duration,var(--default-transition-duration));transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function))}.z-icon-button:focus{--tw-outline-style:none;outline-style:none}.z-icon-button-primary{background-color:var(--color-primary);color:var(--color-white)}.z-icon-button-outlined{border-color:var(--color-primary);border-style:var(--tw-border-style);border-width:1px}.z-icon-button-outlined,.z-icon-button-text{color:var(--color-primary)}.z-icon-button-disabled{cursor:not-allowed;opacity:.5}.z-button{cursor:pointer;--tw-font-weight:var(--font-weight-medium);align-items:center;border-radius:3.40282e+38px;display:inline-flex;font-weight:var(--font-weight-medium);justify-content:center;transition-duration:var(--tw-duration,var(--default-transition-duration));transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function))}.z-button:focus{--tw-outline-style:none;outline-style:none}.z-button-small{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height));padding-block:calc(var(--spacing)*1.5);padding-inline:calc(var(--spacing)*2)}.z-button-medium{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));padding-block:calc(var(--spacing)*2);padding-inline:calc(var(--spacing)*3)}.z-button-large{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height));padding-block:calc(var(--spacing)*3);padding-inline:calc(var(--spacing)*4)}.z-button-primary{background-color:var(--color-primary);color:var(--color-white)}.z-button-outlined{border-color:var(--color-primary);border-style:var(--tw-border-style);border-width:1px;color:var(--color-primary)}.z-button-disabled{cursor:not-allowed;opacity:.5}.z-button-text{margin-inline:calc(var(--spacing)*2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.z-input-area-label{margin-bottom:calc(var(--spacing)*1);--tw-font-weight:var(--font-weight-medium);display:block;font-weight:var(--font-weight-medium)}.z-input-area-input,.z-input-area-label{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.z-input-area-input{border-radius:var(--radius-lg);border-style:var(--tw-border-style);padding-block:calc(var(--spacing)*2);padding-inline:calc(var(--spacing)*4);--tw-ring-color:var(--color-primary);border-width:1px;width:100%}.z-input-area-input:focus{border-color:var(--color-primary);--tw-outline-style:none;outline-style:none}.z-input-area-error{color:var(--color-red-500);font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height));margin-top:calc(var(--spacing)*1)}.z-input-label{margin-bottom:calc(var(--spacing)*1);--tw-font-weight:var(--font-weight-medium);display:block;font-weight:var(--font-weight-medium)}.z-input,.z-input-label{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.z-input{border-style:var(--tw-border-style);padding-block:calc(var(--spacing)*2);padding-inline:calc(var(--spacing)*4);--tw-ring-color:var(--color-primary);border-radius:3.40282e+38px;border-width:1px;width:100%}.z-input:focus{border-color:var(--color-primary);--tw-outline-style:none;outline-style:none}.z-input-error{color:var(--color-red-500);font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height));margin-top:calc(var(--spacing)*1)}.z-select-input-label{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));margin-bottom:calc(var(--spacing)*1);--tw-font-weight:var(--font-weight-medium);display:block;font-weight:var(--font-weight-medium)}.z-tag-or-status-item{align-items:center;border-radius:var(--radius-2xl);gap:calc(var(--spacing)*2);padding-block:calc(var(--spacing)*1.5);padding-inline:calc(var(--spacing)*3);--tw-shadow:0 1px 2px 0 var(--tw-shadow-color,#0000000d);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow);display:inline-flex}.z-tag-or-status-item .z-tag-or-status-item-name{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height));max-width:calc(var(--spacing)*20)}.z-tag-or-status-item .z-tag-or-status-item-icon{border-radius:3.40282e+38px;height:calc(var(--spacing)*4);width:calc(var(--spacing)*4)}.z-context-input{align-items:center;display:flex;flex-direction:row;margin-block:calc(var(--spacing)*1)}.z-context-input-key{border-bottom-left-radius:var(--radius-3xl);border-style:var(--tw-border-style);border-top-left-radius:var(--radius-3xl);font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));padding-block:calc(var(--spacing)*2);padding-inline:calc(var(--spacing)*4);width:100%;--tw-ring-color:var(--color-primary);border-width:1px;flex:1}.z-context-input-key:focus{border-color:var(--color-primary);--tw-outline-style:none;outline-style:none}.z-context-input-value{border-bottom-right-radius:var(--radius-3xl);border-style:var(--tw-border-style);border-top-right-radius:var(--radius-3xl);font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));min-height:2.4rem;padding-block:calc(var(--spacing)*2);padding-inline:calc(var(--spacing)*4);width:100%;--tw-ring-color:var(--color-primary);border-width:1px;flex:2}.z-context-input-value:focus{border-color:var(--color-primary);--tw-outline-style:none;outline-style:none}.z-text-with-link{color:var(--color-blue-600);text-decoration-line:underline}.z-button-group{display:inline-flex}.z-button-group-tab{border-radius:var(--radius-md);display:flex;gap:calc(var(--spacing)*1);padding:calc(var(--spacing)*.5)!important}.z-button-group-item{border-style:var(--tw-border-style);cursor:pointer;--tw-font-weight:var(--font-weight-medium);align-items:center;border-width:1px;display:inline-flex;font-weight:var(--font-weight-medium);justify-content:center;transition-duration:var(--tw-duration,var(--default-transition-duration));transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function))}.z-button-group-item:focus{--tw-outline-style:none;outline-style:none}.z-button-group-item-tab{align-items:center;border-radius:var(--radius-sm);border-style:var(--tw-border-style)!important;border-width:0!important;display:flex;flex:1;flex-direction:column;gap:calc(var(--spacing)*2);justify-content:center;padding:calc(var(--spacing)*1)!important}.z-button-group-item-tab-selected{background-color:var(--color-white);--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a),0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.z-button-group-item-tab-selected,.z-button-group-item-tab-unselected{border-style:var(--tw-border-style)!important;border-width:0!important}.z-button-group-small{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height));padding-block:calc(var(--spacing)*1.5);padding-inline:calc(var(--spacing)*2)}.z-button-group-medium{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));padding-block:calc(var(--spacing)*2);padding-inline:calc(var(--spacing)*3)}.z-button-group-large{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height));padding-block:calc(var(--spacing)*3);padding-inline:calc(var(--spacing)*4)}.z-button-group-item-first{border-bottom-left-radius:3.40282e+38px;border-top-left-radius:3.40282e+38px}.z-button-group-item-last{border-bottom-right-radius:3.40282e+38px;border-top-right-radius:3.40282e+38px}.z-button-group-item-middle{border-radius:0}.z-button-group-item-primary-selected{background-color:var(--color-primary);border-color:var(--color-primary);color:var(--color-white)}.z-button-group-item-primary-unselected{background-color:var(--color-white);border-color:var(--color-primary);color:var(--color-primary)}.z-button-group-item-outlined-selected{background-color:var(--color-primary);border-color:var(--color-primary);color:var(--color-white)}.z-button-group-item-outlined-unselected{background-color:#0000;border-color:var(--color-primary);color:var(--color-primary)}.z-button-group-item-disabled{cursor:not-allowed;opacity:.5}.z-button-group-item:not(:first-child){margin-left:-1px}}@layer utilities{.hidden{display:none}.hidden\\!{display:none!important}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.filter{filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}}.scroll-container::-webkit-scrollbar{background:#0000001a;height:8px;width:8px}.scroll-container:active::-webkit-scrollbar,.scroll-container:hover::-webkit-scrollbar{background:#0003}.scroll-container:active::-webkit-scrollbar-thumb,.scroll-container:hover::-webkit-scrollbar-thumb{background:#0006;border-radius:4px}[data-theme=light] .text-primary{color:var(--color-black)}[data-theme=dark] .text-primary{color:var(--color-white)}[data-theme=light] .text-gray{color:var(--color-gray-500)}[data-theme=dark] .text-gray{color:var(--color-gray-300)}[data-theme=light] .text-accent{color:var(--color-primary)}[data-theme=dark] .text-accent{color:var(--color-primary-dark)}[data-theme=light] .bg-surface{background-color:var(--color-background,#fff)}[data-theme=dark] .bg-surface{background-color:var(--color-background-dark,#23292d)}[data-theme=light] .bg-paper{background-color:var(--color-gray-100)}[data-theme=dark] .bg-paper{background-color:var(--color-gray-700)}[data-theme=light] .bg-time-badge{background-color:#0000004d}[data-theme=dark] .bg-time-badge{background-color:#ffffff4d}[data-theme=light] .bg-primary{background-color:var(--color-black)}[data-theme=dark] .bg-primary{background-color:var(--color-white)}[data-theme=light] .bg-accent{background-color:var(--color-primary)}[data-theme=dark] .bg-accent{background-color:var(--color-primary-dark)}[data-theme=light] .border-primary{border-color:var(--color-black)}[data-theme=dark] .border-primary{border-color:var(--color-white)}[data-theme=light] .border-divider{border-color:var(--color-gray-200)}[data-theme=dark] .border-divider{border-color:var(--color-gray-600)}[data-theme=light] .border-accent{border-color:var(--color-primary)}[data-theme=dark] .border-accent{border-color:var(--color-primary-dark)}.z-text-light{color:var(--color-black)}.z-text-dark{color:var(--color-white)}.z-text-primary-light{color:var(--color-primary)}.z-text-primary-dark{color:var(--color-primary-dark)}.z-text-gray-light{color:var(--color-gray-500)}.z-text-gray-dark{color:var(--color-gray-300)}.z-text-background-light{color:var(--color-background)}.z-text-background-dark{color:var(--color-background-dark)}.z-border-light{border-color:var(--color-black)}.z-border-dark{border-color:var(--color-white)}.z-border-primary-light{border-color:var(--color-primary)}.z-border-primary-dark{border-color:var(--color-primary-dark)}.z-border-divider-light{border-color:var(--color-gray-400)}.z-border-divider-dark{border-color:var(--color-gray-300)}.z-search-input-background-light{background-color:var(--color-gray-200)}.z-search-input-background-dark{background-color:var(--color-gray-500)}.z-chat-input-background-light{background-color:var(--color-white)}.z-chat-input-background-dark{background-color:var(--color-gray-700)}.z-placeholder-light::placeholder{color:var(--color-gray-500)}.z-placeholder-dark::placeholder{color:var(--color-gray-200)}.z-background-primary-light{background-color:var(--color-primary)}.z-background-primary-dark{background-color:var(--color-primary-dark)}.z-background-light{background-color:var(--color-background)}.z-background-dark{background-color:var(--color-background-dark)}.z-paper-light{background-color:var(--color-gray-100)}.z-paper-dark{background-color:var(--color-gray-700)}.z-bg-gray-light{background-color:var(--color-gray-500)}.z-bg-gray-dark{background-color:var(--color-gray-300)}.z-width-100{width:100%}.z-width-90{width:90%}.z-width-75{width:75%}.z-width-50{width:50%}.z-width-25{width:25%}.z-width-0{width:0}.z-animate-width{transition-duration:.5s;transition-property:width;transition-timing-function:cubic-bezier(.4,0,.2,1)}.z-animate-grid-template-cols{transition:grid-template-rows .5s}[type=checkbox]{background-color:var(--color-gray-300);border-color:var(--color-gray-300);border-radius:4px;cursor:pointer}[type=checkbox]:checked,[type=checkbox]:indeterminate{background-color:var(--color-primary);border-color:var(--color-primary);border-radius:4px;cursor:pointer}[type=checkbox]:focus{offset:0;outline-offset:0;--tw-ring-color:var(--color-primary);outline:none}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.grid-cols-1{grid-template-columns:1fr}.grid-cols-1_3{grid-template-columns:1fr 3fr}.grid-cols-1_2_1{grid-template-columns:1fr 2fr 1fr}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer utilities{.relative{position:relative}.size-5{height:calc(var(--spacing)*5);width:calc(var(--spacing)*5)}.rotate-45{rotate:45deg}.text-blue-500{color:var(--color-blue-500)}.text-green-500{color:var(--color-green-500)}.text-primary{color:var(--color-primary)}.container{width:100%}.\\!hidden{display:none!important}.cursor-pointer{cursor:pointer}.border-primary{border-color:var(--color-primary)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.mt-auto{margin-top:auto}.mb-2{margin-bottom:calc(var(--spacing)*2)}.mb-auto{margin-bottom:auto}.text-black{color:var(--color-black)}}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer utilities{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer utilities{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer utilities{:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-end:calc(var(--spacing)*2*(1 - var(--tw-space-y-reverse)));margin-block-start:calc(var(--spacing)*2*var(--tw-space-y-reverse))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.col-span-2{grid-column:span 2/span 2}.my-2{margin-block:calc(var(--spacing)*2)}.w-xl{width:var(--container-xl)}.w-xs{width:var(--container-xs)}.m-auto{margin:auto}.size-32{height:calc(var(--spacing)*32);width:calc(var(--spacing)*32)}.bg-pink-100{background-color:var(--color-pink-100)}.visible{visibility:visible}.-top-12{top:calc(var(--spacing)*-12)}.-top-24{top:calc(var(--spacing)*-24)}.mx-auto{margin-inline:auto}.mt-10{margin-top:calc(var(--spacing)*10)}.mb-10{margin-bottom:calc(var(--spacing)*10)}.inline-block{display:inline-block}.size-18{height:calc(var(--spacing)*18);width:calc(var(--spacing)*18)}.p-4{padding:calc(var(--spacing)*4)}.px-4{padding-inline:calc(var(--spacing)*4)}.pt-4{padding-top:calc(var(--spacing)*4)}.pb-8{padding-bottom:calc(var(--spacing)*8)}.mt-1{margin-top:calc(var(--spacing)*1)}.line-clamp-3{-webkit-line-clamp:3;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.size-3{height:calc(var(--spacing)*3);width:calc(var(--spacing)*3)}.size-4{height:calc(var(--spacing)*4);width:calc(var(--spacing)*4)}.size-8{height:calc(var(--spacing)*8);width:calc(var(--spacing)*8)}.max-w-3xs{max-width:var(--container-3xs)}.max-w-sm{max-width:var(--container-sm)}.resize{resize:both}.rounded-br-\\[0\\]{border-bottom-right-radius:0}.rounded-bl-\\[0\\]{border-bottom-left-radius:0}.bg-black{background-color:var(--color-black)}.bg-white{background-color:var(--color-white)}.p-2{padding:calc(var(--spacing)*2)}.p-3{padding:calc(var(--spacing)*3)}.px-3{padding-inline:calc(var(--spacing)*3)}.py-2{padding-block:calc(var(--spacing)*2)}.text-white{color:var(--color-white)}.underline{text-decoration-line:underline}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.size-42{height:calc(var(--spacing)*42);width:calc(var(--spacing)*42)}.h-20{height:calc(var(--spacing)*20)}.w-42{width:calc(var(--spacing)*42)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.absolute{position:absolute}.right-full{right:100%}.-bottom-2{bottom:calc(var(--spacing)*-2)}.left-full{left:100%}.mr-2{margin-right:calc(var(--spacing)*2)}.mb-0\\.5{margin-bottom:calc(var(--spacing)*.5)}.mb-2\\.5{margin-bottom:calc(var(--spacing)*2.5)}.ml-2{margin-left:calc(var(--spacing)*2)}.flex{display:flex}.size-6{height:calc(var(--spacing)*6);width:calc(var(--spacing)*6)}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.items-center{align-items:center}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-start{justify-content:flex-start}.rounded-full{border-radius:3.40282e+38px}.bg-yellow-300{background-color:var(--color-yellow-300)}.pl-10{padding-left:calc(var(--spacing)*10)}.text-left{text-align:left}.text-right{text-align:right}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.w-full{width:100%}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.-right-0\\.5{right:calc(var(--spacing)*-.5)}.-bottom-0\\.5{bottom:calc(var(--spacing)*-.5)}.col-span-3{grid-column:span 3/span 3}.mt-2{margin-top:calc(var(--spacing)*2)}.flex-wrap{flex-wrap:wrap}.gap-y-1{row-gap:calc(var(--spacing)*1)}.border-b-\\[0\\.5px\\]{border-bottom-style:var(--tw-border-style);border-bottom-width:.5px}.pt-2{padding-top:calc(var(--spacing)*2)}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.whitespace-nowrap{white-space:nowrap}.border-transparent{border-color:#0000}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.pointer-events-auto{pointer-events:auto}.pointer-events-none{pointer-events:none}.fixed{position:fixed}.inset-0{inset:calc(var(--spacing)*0)}.top-3{top:calc(var(--spacing)*3)}.right-3{right:calc(var(--spacing)*3)}.right-4{right:calc(var(--spacing)*4)}.bottom-3{bottom:calc(var(--spacing)*3)}.left-3{left:calc(var(--spacing)*3)}.z-10{z-index:10}.z-\\[80\\]{z-index:80}.mt-4{margin-top:calc(var(--spacing)*4)}.mt-6{margin-top:calc(var(--spacing)*6)}.mb-4{margin-bottom:calc(var(--spacing)*4)}.contents{display:contents}.grid{display:grid}.inline-flex{display:inline-flex}.aspect-square{aspect-ratio:1}.size-12{height:calc(var(--spacing)*12);width:calc(var(--spacing)*12)}.size-14{height:calc(var(--spacing)*14);width:calc(var(--spacing)*14)}.h-7{height:calc(var(--spacing)*7)}.h-8{height:calc(var(--spacing)*8)}.h-9{height:calc(var(--spacing)*9)}.h-\\[180px\\]{height:180px}.h-\\[220px\\]{height:220px}.h-\\[280px\\]{height:280px}.h-full{height:100%}.w-7{width:calc(var(--spacing)*7)}.w-8{width:calc(var(--spacing)*8)}.w-9{width:calc(var(--spacing)*9)}.w-\\[200px\\]{width:200px}.w-\\[250px\\]{width:250px}.max-w-full{max-width:100%}.max-w-md{max-width:var(--container-md)}.max-w-xs{max-width:var(--container-xs)}.flex-1{flex:1}.flex-shrink-0,.shrink-0{flex-shrink:0}.animate-spin{animation:var(--animate-spin)}.cursor-not-allowed{cursor:not-allowed}.resize-none{resize:none}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.items-end{align-items:flex-end}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.gap-1{gap:calc(var(--spacing)*1)}.gap-2{gap:calc(var(--spacing)*2)}.gap-3{gap:calc(var(--spacing)*3)}.gap-4{gap:calc(var(--spacing)*4)}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-\\[18px\\]{border-radius:18px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.border{border-style:var(--tw-border-style);border-width:1px}.border-0{border-style:var(--tw-border-style);border-width:0}.border-\\[1\\.5px\\]{border-style:var(--tw-border-style);border-width:1.5px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-b-2{border-bottom-style:var(--tw-border-style);border-bottom-width:2px}.border-b-\\[1\\.5px\\]{border-bottom-style:var(--tw-border-style);border-bottom-width:1.5px}.border-l{border-left-style:var(--tw-border-style);border-left-width:1px}.border-dashed{--tw-border-style:dashed;border-style:dashed}.border-none{--tw-border-style:none;border-style:none}.border-current{border-color:currentColor}.border-red-500{border-color:var(--color-red-500)}.bg-slate-900\\/40{background-color:#0f172b66}}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer utilities{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer utilities{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer utilities{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer utilities{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer utilities{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer utilities{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer utilities{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer utilities{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer utilities{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer utilities{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer utilities{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer utilities{@supports (color:color-mix(in lab,red,red)){.bg-slate-900\\/40{background-color:color-mix(in oklab,var(--color-slate-900)40%,transparent)}}.bg-slate-900\\/60{background-color:#0f172b99}@supports (color:color-mix(in lab,red,red)){.bg-slate-900\\/60{background-color:color-mix(in oklab,var(--color-slate-900)60%,transparent)}}.bg-transparent{background-color:#0000}.bg-white\\/90{background-color:#ffffffe6}@supports (color:color-mix(in lab,red,red)){.bg-white\\/90{background-color:color-mix(in srgb,#fff90%,transparent);background-color:color-mix(in oklab,var(--color-white)90%,transparent)}}.object-cover{object-fit:cover}.p-1{padding:calc(var(--spacing)*1)}.p-5{padding:calc(var(--spacing)*5)}.p-6{padding:calc(var(--spacing)*6)}.px-2{padding-inline:calc(var(--spacing)*2)}.px-6{padding-inline:calc(var(--spacing)*6)}.px-8{padding-inline:calc(var(--spacing)*8)}.py-1\\.5{padding-block:calc(var(--spacing)*1.5)}.py-3{padding-block:calc(var(--spacing)*3)}.py-4{padding-block:calc(var(--spacing)*4)}.py-12{padding-block:calc(var(--spacing)*12)}.pr-16{padding-right:calc(var(--spacing)*16)}.pb-2{padding-bottom:calc(var(--spacing)*2)}.pl-2{padding-left:calc(var(--spacing)*2)}.text-center{text-align:center}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-\\[13px\\]{font-size:13px}.leading-snug{--tw-leading:var(--leading-snug);line-height:var(--leading-snug)}.leading-tight{--tw-leading:var(--leading-tight);line-height:var(--leading-tight)}.text-red-500{color:var(--color-red-500)}.text-slate-700{color:var(--color-slate-700)}.opacity-0{opacity:0}.opacity-60{opacity:.6}.opacity-80{opacity:.8}.shadow,.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a)}.shadow,.shadow-sm,.shadow-xl{box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px var(--tw-shadow-color,#0000001a),0 8px 10px -6px var(--tw-shadow-color,#0000001a)}.ring-primary{--tw-ring-color:var(--color-primary)}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function))}.transition-all,.transition-colors{transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function))}.transition-opacity{transition-duration:var(--tw-duration,var(--default-transition-duration));transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function))}.focus\\:border-red-500:focus{border-color:var(--color-red-500)}.focus\\:ring-0:focus{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor)}.focus\\:ring-0:focus,.focus\\:ring-2:focus{box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,)0 0 0 calc(2px + var(--tw-ring-offset-width))var(--tw-ring-color,currentcolor)}.focus\\:ring-red-200:focus{--tw-ring-color:var(--color-red-200)}.focus\\:ring-red-500:focus{--tw-ring-color:var(--color-red-500)}.focus\\:ring-slate-200:focus{--tw-ring-color:var(--color-slate-200)}.focus\\:outline-none:focus{--tw-outline-style:none;outline-style:none}}@keyframes spin{to{transform:rotate(1turn)}}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer utilities{.top-1\\/2{top:50%}.right-2{right:calc(var(--spacing)*2)}.ml-auto{margin-left:auto}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.h-10{height:calc(var(--spacing)*10)}.min-h-0{min-height:calc(var(--spacing)*0)}.w-10{width:calc(var(--spacing)*10)}.min-w-0{min-width:calc(var(--spacing)*0)}.-translate-y-1\\/2{--tw-translate-y:-50%;translate:var(--tw-translate-x)var(--tw-translate-y)}.gap-2\\.5{gap:calc(var(--spacing)*2.5)}.overflow-y-auto{overflow-y:auto}.py-2\\.5{padding-block:calc(var(--spacing)*2.5)}.pr-9{padding-right:calc(var(--spacing)*9)}.break-words{overflow-wrap:break-word}.text-gray-400{color:var(--color-gray-400)}.focus\\:border-primary:focus{border-color:var(--color-primary)}.disabled\\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\\:opacity-40:disabled{opacity:.4}.col-span-full{grid-column:1/-1}.h-16{height:calc(var(--spacing)*16)}.w-16{width:calc(var(--spacing)*16)}.auto-rows-auto{grid-auto-rows:auto}.content-start{align-content:flex-start}.p-1\\.5{padding:calc(var(--spacing)*1.5)}.size-16{height:calc(var(--spacing)*16);width:calc(var(--spacing)*16)}.size-\\[8px\\]{height:8px;width:8px}.size-\\[10px\\]{height:10px;width:10px}.text-yellow-500{color:var(--color-yellow-500)}.inset-y-0{inset-block:calc(var(--spacing)*0)}.size-10{height:calc(var(--spacing)*10);width:calc(var(--spacing)*10)}.h-\\[160px\\]{height:160px}.h-\\[200px\\]{height:200px}.w-\\[240px\\]{width:240px}.shrink-0{flex-shrink:0}.gap-1\\.5{gap:calc(var(--spacing)*1.5)}.self-end{align-self:flex-end}.py-1{padding-block:calc(var(--spacing)*1)}.py-10{padding-block:calc(var(--spacing)*10)}.pb-1{padding-bottom:calc(var(--spacing)*1)}.text-\\[10px\\]{font-size:10px}.text-\\[11px\\]{font-size:11px}.leading-none{--tw-leading:1;line-height:1}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.whitespace-pre-line{white-space:pre-line}.text-slate-500{color:var(--color-slate-500)}.opacity-70{opacity:.7}.shadow-\\[0_8px_24px_rgba\\(15\\,23\\,42\\,0\\.08\\)\\]{--tw-shadow:0 8px 24px var(--tw-shadow-color,#0f172a14)}.shadow-\\[0_8px_24px_rgba\\(15\\,23\\,42\\,0\\.08\\)\\],.shadow-sm{box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a),0 1px 2px -1px var(--tw-shadow-color,#0000001a)}.col-span-1{grid-column:span 1/span 1}.m-2{margin:calc(var(--spacing)*2)}.mx-4{margin-inline:calc(var(--spacing)*4)}.ml-0\\.5{margin-left:calc(var(--spacing)*.5)}.w-1\\/2{width:50%}.max-w-32{max-width:calc(var(--spacing)*32)}.translate-y-0{--tw-translate-y:calc(var(--spacing)*0)}.translate-y-0,.translate-y-full{translate:var(--tw-translate-x)var(--tw-translate-y)}.translate-y-full{--tw-translate-y:100%}.text-green-700{color:var(--color-green-700)}.text-red-700{color:var(--color-red-700)}.capitalize{text-transform:capitalize}.opacity-100{opacity:1}}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer utilities{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer utilities;/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer utilities{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer utilities{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer utilities{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer utilities{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}/*! tailwindcss v4.1.16 | MIT License | https://tailwindcss.com */@layer properties{}@layer base{}@layer components{.chat-item .chat-item-content-main-name,.chat-item .chat-item-content-main-time{-webkit-line-clamp:1;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.z-icon-button-outlined,.z-icon-button-text{color:var(--color-primary)}.z-input,.z-input-area-input,.z-input-area-label,.z-input-label{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.z-button-group-item-tab,.z-button-group-item-tab-selected{border-style:var(--tw-border-style)!important;border-width:0!important}}@layer utilities{.focus\\:ring-0:focus,.focus\\:ring-2:focus,.shadow,.shadow-\\[0_8px_24px_rgba\\(15\\,23\\,42\\,0\\.08\\)\\],.shadow-sm,.shadow-xl{box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.translate-y-0,.translate-y-full{translate:var(--tw-translate-x)var(--tw-translate-y)}}@property --tw-space-y-reverse{syntax:\"*\";inherits:false;initial-value:0}@property --tw-leading{syntax:\"*\";inherits:false}@property --tw-translate-x{syntax:\"*\";inherits:false;initial-value:0}@property --tw-translate-y{syntax:\"*\";inherits:false;initial-value:0}@property --tw-translate-z{syntax:\"*\";inherits:false;initial-value:0}:host{display:block}.chat-header{height:60px;padding-block:calc(var(--spacing)*3);padding-inline:calc(var(--spacing)*2);--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a),0 4px 6px -4px var(--tw-shadow-color,#0000001a);align-items:center;box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow);display:flex;justify-content:space-between;overflow-x:auto;width:100%}:where(.chat-header>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-end:calc(var(--spacing)*1*(1 - var(--tw-space-x-reverse)));margin-inline-start:calc(var(--spacing)*1*var(--tw-space-x-reverse))}.chat-header-avatar-wrapper{align-items:center;cursor:pointer;display:flex;gap:calc(var(--spacing)*2);margin-block:auto}.chat-header-avatar-badge{bottom:-2px;position:absolute;right:-2px}.chat-header-name{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height));text-overflow:ellipsis;white-space:nowrap;--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold);overflow:hidden}.chat-header-toolbar-wrapper{gap:calc(var(--spacing)*1);margin-block:auto}.chat-header-connection-wrapper,.chat-header-toolbar-wrapper{align-items:center;display:flex}:where(.chat-header-connection-wrapper>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-end:calc(var(--spacing)*1*(1 - var(--tw-space-x-reverse)));margin-inline-start:calc(var(--spacing)*1*var(--tw-space-x-reverse))}.chat-header-connection-icon{border-radius:3.40282e+38px;height:calc(var(--spacing)*4);width:calc(var(--spacing)*4)}.chat-header-connection-text{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height));overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@property --tw-space-x-reverse{syntax:\"*\";inherits:false;initial-value:0}@property --tw-shadow{syntax:\"*\";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:\"*\";inherits:false}@property --tw-shadow-alpha{syntax:\"<percentage>\";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:\"*\";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:\"*\";inherits:false}@property --tw-inset-shadow-alpha{syntax:\"<percentage>\";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:\"*\";inherits:false}@property --tw-ring-shadow{syntax:\"*\";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:\"*\";inherits:false}@property --tw-inset-ring-shadow{syntax:\"*\";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:\"*\";inherits:false}@property --tw-ring-offset-width{syntax:\"<length>\";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:\"*\";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:\"*\";inherits:false;initial-value:0 0 #0000}@property --tw-font-weight{syntax:\"*\";inherits:false}@property --tw-blur{syntax:\"*\";inherits:false}@property --tw-brightness{syntax:\"*\";inherits:false}@property --tw-contrast{syntax:\"*\";inherits:false}@property --tw-grayscale{syntax:\"*\";inherits:false}@property --tw-hue-rotate{syntax:\"*\";inherits:false}@property --tw-invert{syntax:\"*\";inherits:false}@property --tw-opacity{syntax:\"*\";inherits:false}@property --tw-saturate{syntax:\"*\";inherits:false}@property --tw-sepia{syntax:\"*\";inherits:false}@property --tw-drop-shadow{syntax:\"*\";inherits:false}@property --tw-drop-shadow-color{syntax:\"*\";inherits:false}@property --tw-drop-shadow-alpha{syntax:\"<percentage>\";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:\"*\";inherits:false}@property --tw-border-style{syntax:\"*\";inherits:false;initial-value:solid}@media (forced-colors:active){[type=checkbox]:checked,[type=radio]:checked{appearance:auto}[type=checkbox]:indeterminate{appearance:auto}[type=checkbox]:checked,[type=checkbox]:indeterminate,[type=radio]:checked{appearance:auto}}@media (hover:hover){.z-button-outlined:hover,.z-button-primary:hover,.z-icon-button-outlined:hover,.z-icon-button-primary:hover,.z-icon-button-text:hover{--tw-brightness:brightness(110%);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.z-button-group-item-tab:hover{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a),0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.z-button-group-item-tab-unselected:hover{background-color:var(--color-white)}.z-button-group-item-primary-unselected:hover{--tw-brightness:brightness(95%);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.z-button-group-item-outlined-unselected:hover{background-color:#e028481a}@supports (color:color-mix(in lab,red,red)){.z-button-group-item-outlined-unselected:hover{background-color:color-mix(in oklab,var(--color-primary)10%,transparent);background-color:color-mix(in srgb,#e0284810%,transparent)}}.hover\\:brightness-110:hover{--tw-brightness:brightness(110%);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}.group-hover\\:opacity-100:is(:where(.group):hover *){opacity:1}.hover\\:bg-red-50:hover{background-color:var(--color-red-50)}.hover\\:bg-slate-100:hover{background-color:var(--color-slate-100)}.hover\\:bg-white:hover{background-color:var(--color-white)}.hover\\:text-gray-600:hover{color:var(--color-gray-600)}.hover\\:opacity-100:hover{opacity:1}.z-button-outlined:hover,.z-button-primary:hover,.z-icon-button-outlined:hover,.z-icon-button-primary:hover,.z-icon-button-text:hover{--tw-brightness:brightness(110%);filter:var(--tw-blur,)var(--tw-brightness,)var(--tw-contrast,)var(--tw-grayscale,)var(--tw-hue-rotate,)var(--tw-invert,)var(--tw-saturate,)var(--tw-sepia,)var(--tw-drop-shadow,)}}@media screen and (min-width:0){.z-max-height{height:calc(100vh - 56px)}}@media screen and (min-width:600px){.z-max-height{height:calc(100vh - 64px)}}@media (min-width:40rem){.container{max-width:40rem}.sm\\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\\:min-w-0{min-width:calc(var(--spacing)*0)}.sm\\:flex-row{flex-direction:row}}@media (min-width:48rem){.container{max-width:48rem}.md\\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (min-width:64rem){.container{max-width:64rem}.lg\\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}@media not all and (min-width:40rem){.max-sm\\:hidden{display:none}}";
80
-
81
- const ChatHeader = /*@__PURE__*/ proxyCustomElement(class ChatHeader extends H {
82
- constructor(registerHost) {
83
- super();
84
- if (registerHost !== false) {
85
- this.__registerHost();
86
- }
87
- }
88
- disposeListener;
89
- isPinLoading = false;
90
- isSpamLoading = false;
91
- isReadLoading = false;
92
- isPin = false;
93
- isSpam = false;
94
- isUnRead = false;
95
- selectedValue = 'admin';
96
- componentDidLoad() {
97
- //Initialize
98
- const selectedChat = selectedChatStore.get('selectedChat');
99
- this.isPin = selectedChat.pin;
100
- this.isSpam = selectedChat.spam;
101
- this.isUnRead = isUnread();
102
- }
103
- componentWillLoad() {
104
- //Watch selectedChat change
105
- this.disposeListener = selectedChatStore.onChange('selectedChat', async (newChat) => {
106
- if (!newChat) {
107
- this.isPin = false;
108
- this.isSpam = false;
109
- this.isUnRead = false;
110
- return;
111
- }
112
- this.isPin = newChat.pin;
113
- this.isSpam = newChat.spam;
114
- this.isUnRead = isUnread();
115
- });
116
- //Watch user change
117
- this.disposeListener = userStore.onChange('user', async (newUser) => {
118
- if (!newUser) {
119
- this.selectedValue = 'admin';
120
- return;
121
- }
122
- this.selectedValue = newUser.context === 'contactadmin' ? 'admin' : 'bot';
123
- });
124
- }
125
- disconnectedCallback() {
126
- this.disposeListener?.();
127
- }
128
- render() {
129
- const selectedChat = selectedChatStore.get('selectedChat');
130
- const platformColor = selectedChat?.channel === 'line' ? 'text-green-500' : 'text-blue-500';
131
- const theme = configStore.get('theme');
132
- const isMobile = responsiveStore.get('isMobile');
133
- const isFbOrIg = selectedChat?.channel === 'facebook' || selectedChat?.channel === 'instagram';
134
- const handleBackToChatList = () => {
135
- selectedChatStore.reset();
136
- if (selectedChat?.id) {
137
- leaveRoom(selectedChat?.id);
138
- }
139
- };
140
- const handleShowProfile = () => {
141
- if (isMobile) {
142
- profilePanelStore.set('isShow', true);
143
- }
144
- };
145
- const handleToggleReadMessageClick = async () => {
146
- try {
147
- this.isReadLoading = true;
148
- const isSuccess = this.isUnRead ? await serviceReadMessage(selectedChat?.id) : await serviceUnReadMessage(selectedChat?.id);
149
- if (isSuccess) {
150
- this.isUnRead = !this.isUnRead;
151
- }
152
- }
153
- catch (error) {
154
- handleError(error, 'Failed to toggle read message status');
155
- }
156
- finally {
157
- this.isReadLoading = false;
158
- }
159
- };
160
- const handleSyncChatMessage = async () => {
161
- try {
162
- selectedChatStore.set('isSyncingMessage', true);
163
- await syncMessage({ sessionId: selectedChat?.id });
164
- }
165
- catch (error) {
166
- handleError(error, 'Failed to sync chat message');
167
- }
168
- };
169
- const handleSyncTags = async () => {
170
- try {
171
- selectedChatStore.set('isSyncingTag', true);
172
- await syncTags({ sessionId: selectedChat?.id });
173
- }
174
- catch (error) {
175
- handleError(error, 'Failed to sync tags');
176
- }
177
- };
178
- const handleTogglePinChatClick = async () => {
179
- try {
180
- this.isPinLoading = true;
181
- const _pin = !this.isPin;
182
- const { code } = await updateChat({
183
- sessionId: selectedChat?.id,
184
- pin: _pin,
185
- });
186
- if (code === 'chat-updated') {
187
- const pinChats = chatsStore
188
- .get('chats')
189
- .map(chat => {
190
- if (chat.id === selectedChat?.id) {
191
- return {
192
- ...chat,
193
- pin: _pin,
194
- };
195
- }
196
- return chat;
197
- })
198
- .sort((a, b) => {
199
- if (a.pin !== b.pin) {
200
- return a.pin ? -1 : 1;
201
- }
202
- const aTime = a.last_message_at ? new Date(a.last_message_at).getTime() : 0;
203
- const bTime = b.last_message_at ? new Date(b.last_message_at).getTime() : 0;
204
- return bTime - aTime;
205
- });
206
- chatsStore.set('chats', pinChats);
207
- this.isPin = _pin;
208
- }
209
- }
210
- catch (error) {
211
- handleError(error, 'Failed to pin chat');
212
- }
213
- finally {
214
- this.isPinLoading = false;
215
- }
216
- };
217
- const handleToggleSpamChatClick = async () => {
218
- try {
219
- this.isSpamLoading = true;
220
- const _spam = !this.isSpam;
221
- const { code } = await updateChat({
222
- sessionId: selectedChat?.id,
223
- spam: _spam,
224
- });
225
- if (code === 'chat-updated') {
226
- //Requirement: No need to update chatStore waiting user refresh or click other chat
227
- const updateSelectedChat = {
228
- ...selectedChatStore.get('selectedChat'),
229
- spam: _spam,
230
- };
231
- selectedChatStore.set('selectedChat', updateSelectedChat);
232
- this.isSpam = _spam;
233
- }
234
- }
235
- catch (error) {
236
- handleError(error, 'Failed to toggle spam status');
237
- }
238
- finally {
239
- this.isSpamLoading = false;
240
- }
241
- };
242
- const handleSelectBotAdmin = async (newValue) => {
243
- try {
244
- const type = selectedChat?.type === 'group' ? 'group' : 'user';
245
- const user = userStore.get('user');
246
- const context = newValue === 'admin' ? 'contactadmin' : '';
247
- const userResponse = await updateUser({
248
- type,
249
- channel: user.channel,
250
- id: user.id,
251
- context
252
- });
253
- if (['user-updated', 'group-updated'].includes(userResponse.code)) {
254
- this.selectedValue = newValue;
255
- userStore.set('user', {
256
- ...userStore.get('user'),
257
- context
258
- });
259
- }
260
- }
261
- catch (error) {
262
- handleError(error, 'Failed to SelectBotAdmin');
263
- }
264
- };
265
- return (h(Host, { "data-theme": theme }, h("div", { class: "chat-header scroll-container bg-surface" }, h("div", { class: "chat-header-avatar-wrapper", onClick: handleShowProfile }, isMobile && h(ZIconButton, { variant: "none", iconName: "ChevronLeft", onClick: handleBackToChatList }), h("div", { class: "relative" }, h("z-avatar", { pictureUrl: getChatPicture(selectedChat), size: "small" }), selectedChat.type === 'group' &&
266
- h("div", { class: "chat-header-avatar-badge" }, h("z-avatar", { size: "x-small" }))), h("div", null, h("div", { class: "chat-header-name text-primary" }, getChatName(selectedChat)), h("div", { class: "chat-header-connection-wrapper" }, selectedChat?.connection.type === 'zwiz' &&
267
- h("img", { src: `https://zwizai-platform.s3.ap-southeast-1.amazonaws.com/zignal-package/zwiz.png`, alt: "agent avatar zwiz", class: "chat-header-connection-icon", loading: "lazy" }), h("img", { src: getChatChannelPictureUrl(selectedChat), alt: "agent avatar", class: "chat-header-connection-icon", loading: "lazy" }), h("span", { class: `chat-header-connection-text ${platformColor}` }, selectedChat?.connection.name)))), h("div", { class: "chat-header-toolbar-wrapper" }, h(ZIconButton, { variant: "none", iconName: "Pin", addClassIcon: this.isPin ? 'rotate-45 size-5' : 'size-5', isLoading: this.isPinLoading, onClick: handleTogglePinChatClick }), h(ZIconButton, { variant: "none", iconName: this.isSpam ? 'CircleOff' : 'Ban', isLoading: this.isSpamLoading, onClick: handleToggleSpamChatClick }), h(ZIconButton, { variant: "none", iconName: this.isUnRead ? 'MailCheck' : 'Mail', isLoading: this.isReadLoading, onClick: handleToggleReadMessageClick }), selectedChat?.connection.type === 'zwiz' &&
268
- h(ZButtonGroup, { variant: 'tab', options: [
269
- { value: 'admin', label: h(Icon, { name: "UserRound", addClass: `size-5 ${this.selectedValue === 'admin' ? 'text-accent' : 'text-gray'}` }) },
270
- { value: 'bot', label: h(Icon, { name: "Bot", addClass: `size-5 ${this.selectedValue === 'bot' ? 'text-accent' : 'text-gray'}` }) },
271
- ], value: this.selectedValue, onChange: (newValue) => handleSelectBotAdmin(newValue), size: 'small' }), isFbOrIg && (h("menu-list", { referenceSelector: 'chat-header-menu', iconName: "Ellipsis", position: "bottom-end", menuItems: [
272
- { label: 'ดึงประวัติแชท', value: 'sync_message', onClick: handleSyncChatMessage },
273
- ...(selectedChat?.channel === 'facebook' ? [{ label: 'ดึงป้ายกำกับ', value: 'sync_tags', onClick: handleSyncTags }] : []),
274
- ], variant: "none" }))))));
275
- }
276
- static get style() { return chatHeaderCss; }
277
- }, [256, "chat-header", {
278
- "isPinLoading": [32],
279
- "isSpamLoading": [32],
280
- "isReadLoading": [32],
281
- "isPin": [32],
282
- "isSpam": [32],
283
- "isUnRead": [32],
284
- "selectedValue": [32]
285
- }]);
286
- function defineCustomElement() {
287
- if (typeof customElements === "undefined") {
288
- return;
289
- }
290
- const components = ["chat-header", "menu-list", "z-avatar"];
291
- components.forEach(tagName => { switch (tagName) {
292
- case "chat-header":
293
- if (!customElements.get(tagName)) {
294
- customElements.define(tagName, ChatHeader);
295
- }
296
- break;
297
- case "menu-list":
298
- if (!customElements.get(tagName)) {
299
- defineCustomElement$2();
300
- }
301
- break;
302
- case "z-avatar":
303
- if (!customElements.get(tagName)) {
304
- defineCustomElement$1();
305
- }
306
- break;
307
- } });
308
- }
309
- defineCustomElement();
310
-
311
- export { ChatHeader as C, defineCustomElement as d };
312
- //# sourceMappingURL=p-DWTuyVHk.js.map
313
-
314
- //# sourceMappingURL=p-DWTuyVHk.js.map
@@ -1 +0,0 @@
1
- {"file":"p-DWTuyVHk.js","mappings":"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","names":["__stencil_proxyCustomElement","HTMLElement"],"sources":["src/components/internal-component/z-button-group.tsx","src/components/chat-header/chat-header.css?tag=chat-header","src/components/chat-header/chat-header.tsx"],"sourcesContent":["import { FunctionalComponent, h, JSX } from '@stencil/core';\nimport { configStore } from '../../store/store';\n\nexport interface ZButtonGroupOption {\n value: string;\n label: JSX.Element;\n disabled?: boolean;\n}\n\ninterface ZButtonGroupProps {\n id?: string;\n options: ZButtonGroupOption[];\n value?: string;\n onChange?: (value: string) => void;\n size?: 'small' | 'medium' | 'large';\n fullWidth?: boolean;\n variant?: 'primary' | 'outlined' | 'tab';\n}\n\nexport const ZButtonGroup: FunctionalComponent<ZButtonGroupProps> = ({\n id,\n options,\n value,\n onChange,\n size = 'medium',\n fullWidth = false,\n variant = 'primary',\n}) => {\n const theme = configStore.get('theme');\n\n let sizeClass = 'z-button-group-medium';\n if (size === 'small') {\n sizeClass = 'z-button-group-small';\n }\n if (size === 'large') {\n sizeClass = 'z-button-group-large';\n }\n\n const handleButtonClick = (optionValue: string, disabled?: boolean) => {\n if (!disabled && onChange) {\n onChange(optionValue);\n }\n };\n\n return (\n <div\n id={id}\n class={`z-button-group ${variant === 'tab' ? 'z-button-group-tab' : ''} ${sizeClass} ${fullWidth ? 'w-full' : ''}`}\n style={\n variant === 'tab'\n ? { backgroundColor: theme === 'light' ? 'rgba(0,0,0,0.3)' : 'rgba(255,255,255,0.3)' }\n : {}\n }\n >\n {options.map((option, index) => {\n const isSelected = value === option.value;\n const isDisabled = option.disabled || false;\n const isFirst = index === 0;\n const isLast = index === options.length - 1;\n\n let buttonClass = 'z-button-group-item';\n\n if (variant === 'tab') {\n buttonClass += ' z-button-group-item-tab';\n if (isSelected) {\n buttonClass += ' z-button-group-item-tab-selected';\n } else {\n buttonClass += ' z-button-group-item-tab-unselected';\n }\n } else {\n if (isFirst) {\n buttonClass += ' z-button-group-item-first';\n }\n if (isLast) {\n buttonClass += ' z-button-group-item-last';\n }\n if (!isFirst && !isLast) {\n buttonClass += ' z-button-group-item-middle';\n }\n\n if (variant === 'primary') {\n if (isSelected) {\n buttonClass += ' z-button-group-item-primary-selected';\n } else {\n buttonClass += ' z-button-group-item-primary-unselected';\n }\n } else {\n if (isSelected) {\n buttonClass += ' z-button-group-item-outlined-selected';\n } else {\n buttonClass += ' z-button-group-item-outlined-unselected';\n }\n }\n }\n\n if (isDisabled) {\n buttonClass += ' z-button-group-item-disabled';\n }\n\n buttonClass += ` ${sizeClass}`;\n\n return (\n <button\n key={option.value}\n type=\"button\"\n class={buttonClass}\n disabled={isDisabled}\n onClick={() => handleButtonClick(option.value, isDisabled)}\n >\n {option.label}\n </button>\n );\n })}\n </div>\n );\n};\n",":host {\n display: block;\n}\n\n.chat-header {\n @apply w-full px-2 py-3 flex items-center space-x-1 shadow-lg justify-between h-[60px] overflow-x-auto\n}\n\n.chat-header-avatar-wrapper {\n @apply my-auto gap-2 flex items-center cursor-pointer\n}\n\n.chat-header-avatar-badge {\n @apply absolute bottom-[-2px] right-[-2px];\n}\n\n.chat-header-name {\n @apply font-semibold text-sm truncate\n}\n\n.chat-header-toolbar-wrapper {\n @apply my-auto gap-1 flex items-center\n}\n\n.chat-header-connection-wrapper {\n @apply flex items-center space-x-1\n}\n\n.chat-header-connection-icon {\n @apply size-4 rounded-full\n}\n\n.chat-header-connection-text {\n @apply text-xs truncate\n}","import { Component, Host, State, h } from '@stencil/core';\nimport { chatsStore, configStore, profilePanelStore, responsiveStore, selectedChatStore, userStore } from '../../store/store';\nimport { ZIconButton } from '../internal-component/z-icon-button';\nimport { syncMessage, syncTags, updateChat, updateUser } from '../../api';\nimport { leaveRoom } from '../../utils/socket';\nimport { serviceReadMessage, serviceUnReadMessage } from '../../store/message';\nimport { getChatChannelPictureUrl, getChatName, getChatPicture, isUnread } from '../../store/chat';\nimport { handleError } from '../../store/dialog';\nimport { TChatItem } from '../../store/type';\nimport { ZButtonGroup } from '../internal-component/z-button-group';\nimport { Icon } from '../internal-component/icon';\n\n@Component({\n tag: 'chat-header',\n styleUrl: 'chat-header.css',\n})\nexport class ChatHeader {\n private disposeListener: () => void;\n\n @State() isPinLoading = false;\n @State() isSpamLoading = false;\n @State() isReadLoading = false;\n @State() isPin = false;\n @State() isSpam = false;\n @State() isUnRead = false;\n @State() selectedValue = 'admin';\n\n componentDidLoad() {\n //Initialize\n const selectedChat = selectedChatStore.get('selectedChat');\n\n this.isPin = selectedChat.pin;\n this.isSpam = selectedChat.spam;\n this.isUnRead = isUnread();\n }\n\n componentWillLoad() {\n //Watch selectedChat change\n this.disposeListener = selectedChatStore.onChange('selectedChat', async newChat => {\n if (!newChat) {\n this.isPin = false;\n this.isSpam = false;\n this.isUnRead = false;\n return;\n }\n\n this.isPin = newChat.pin;\n this.isSpam = newChat.spam;\n this.isUnRead = isUnread();\n });\n\n //Watch user change\n this.disposeListener = userStore.onChange('user', async newUser => {\n if (!newUser) {\n this.selectedValue = 'admin';\n return;\n }\n\n this.selectedValue = newUser.context === 'contactadmin' ? 'admin' : 'bot';\n });\n }\n\n disconnectedCallback() {\n this.disposeListener?.();\n }\n\n render() {\n const selectedChat = selectedChatStore.get('selectedChat');\n const platformColor = selectedChat?.channel === 'line' ? 'text-green-500' : 'text-blue-500';\n const theme = configStore.get('theme');\n const isMobile = responsiveStore.get('isMobile');\n const isFbOrIg = selectedChat?.channel === 'facebook' || selectedChat?.channel === 'instagram';\n\n const handleBackToChatList = () => {\n selectedChatStore.reset();\n if (selectedChat?.id) {\n leaveRoom(selectedChat?.id);\n }\n };\n\n const handleShowProfile = () => {\n if (isMobile) {\n profilePanelStore.set('isShow', true);\n }\n };\n\n const handleToggleReadMessageClick = async () => {\n try {\n this.isReadLoading = true;\n const isSuccess = this.isUnRead ? await serviceReadMessage(selectedChat?.id) : await serviceUnReadMessage(selectedChat?.id);\n if (isSuccess) {\n this.isUnRead = !this.isUnRead;\n }\n } catch (error: unknown) {\n handleError(error, 'Failed to toggle read message status');\n } finally {\n this.isReadLoading = false;\n }\n };\n\n const handleSyncChatMessage = async () => {\n try {\n selectedChatStore.set('isSyncingMessage', true);\n await syncMessage({ sessionId: selectedChat?.id });\n } catch (error: unknown) {\n handleError(error, 'Failed to sync chat message');\n }\n };\n\n const handleSyncTags = async () => {\n try {\n selectedChatStore.set('isSyncingTag', true);\n await syncTags({ sessionId: selectedChat?.id });\n } catch (error: unknown) {\n handleError(error, 'Failed to sync tags');\n }\n };\n\n const handleTogglePinChatClick = async () => {\n try {\n this.isPinLoading = true;\n const _pin = !this.isPin;\n const { code } = await updateChat({\n sessionId: selectedChat?.id,\n pin: _pin,\n });\n\n if (code === 'chat-updated') {\n const pinChats = chatsStore\n .get('chats')\n .map(chat => {\n if (chat.id === selectedChat?.id) {\n return {\n ...chat,\n pin: _pin,\n };\n }\n return chat;\n })\n .sort((a, b) => {\n if (a.pin !== b.pin) {\n return a.pin ? -1 : 1;\n }\n const aTime = a.last_message_at ? new Date(a.last_message_at).getTime() : 0;\n const bTime = b.last_message_at ? new Date(b.last_message_at).getTime() : 0;\n return bTime - aTime;\n });\n\n chatsStore.set('chats', pinChats);\n this.isPin = _pin;\n }\n } catch (error: unknown) {\n handleError(error, 'Failed to pin chat');\n } finally {\n this.isPinLoading = false;\n }\n };\n\n const handleToggleSpamChatClick = async () => {\n try {\n this.isSpamLoading = true;\n const _spam = !this.isSpam;\n const { code } = await updateChat({\n sessionId: selectedChat?.id,\n spam: _spam,\n });\n\n if (code === 'chat-updated') {\n //Requirement: No need to update chatStore waiting user refresh or click other chat\n const updateSelectedChat: TChatItem = {\n ...selectedChatStore.get('selectedChat'),\n spam: _spam,\n };\n selectedChatStore.set('selectedChat', updateSelectedChat);\n this.isSpam = _spam;\n }\n } catch (error: unknown) {\n handleError(error, 'Failed to toggle spam status');\n } finally {\n this.isSpamLoading = false;\n }\n };\n\n const handleSelectBotAdmin = async (newValue: string) => {\n try {\n const type = selectedChat?.type === 'group' ? 'group' : 'user';\n const user = userStore.get('user');\n const context = newValue === 'admin' ? 'contactadmin' : '';\n const userResponse = await updateUser({\n type,\n channel: user.channel,\n id: user.id,\n context\n });\n\n if (['user-updated', 'group-updated'].includes(userResponse.code)) {\n this.selectedValue = newValue\n userStore.set('user', {\n ...userStore.get('user'),\n context\n });\n }\n } catch (error) {\n handleError(error, 'Failed to SelectBotAdmin');\n }\n }\n\n return (\n <Host data-theme={theme}>\n <div class=\"chat-header scroll-container bg-surface\">\n <div class=\"chat-header-avatar-wrapper\" onClick={handleShowProfile}>\n {isMobile && <ZIconButton variant=\"none\" iconName=\"ChevronLeft\" onClick={handleBackToChatList} />}\n <div class=\"relative\">\n <z-avatar pictureUrl={getChatPicture(selectedChat)} size=\"small\" />\n {selectedChat.type === 'group' &&\n <div class=\"chat-header-avatar-badge\">\n <z-avatar size=\"x-small\" />\n </div>\n }\n </div>\n <div>\n <div class=\"chat-header-name text-primary\">{getChatName(selectedChat)}</div>\n <div class=\"chat-header-connection-wrapper\">\n {selectedChat?.connection.type === 'zwiz' &&\n <img src={`https://zwizai-platform.s3.ap-southeast-1.amazonaws.com/zignal-package/zwiz.png`} alt=\"agent avatar zwiz\" class=\"chat-header-connection-icon\" loading=\"lazy\" />\n }\n <img src={getChatChannelPictureUrl(selectedChat)} alt=\"agent avatar\" class=\"chat-header-connection-icon\" loading=\"lazy\" />\n <span class={`chat-header-connection-text ${platformColor}`}>{selectedChat?.connection.name}</span>\n </div>\n </div>\n </div>\n <div class=\"chat-header-toolbar-wrapper\">\n <ZIconButton\n variant=\"none\"\n iconName=\"Pin\"\n addClassIcon={this.isPin ? 'rotate-45 size-5' : 'size-5'}\n isLoading={this.isPinLoading}\n onClick={handleTogglePinChatClick}\n />\n <ZIconButton variant=\"none\" iconName={this.isSpam ? 'CircleOff' : 'Ban'} isLoading={this.isSpamLoading} onClick={handleToggleSpamChatClick} />\n <ZIconButton variant=\"none\" iconName={this.isUnRead ? 'MailCheck' : 'Mail'} isLoading={this.isReadLoading} onClick={handleToggleReadMessageClick} />\n {selectedChat?.connection.type === 'zwiz' &&\n <ZButtonGroup\n variant='tab'\n options={[\n { value: 'admin', label: <Icon name=\"UserRound\" addClass={`size-5 ${this.selectedValue === 'admin' ? 'text-accent' : 'text-gray'}`} /> },\n { value: 'bot', label: <Icon name=\"Bot\" addClass={`size-5 ${this.selectedValue === 'bot' ? 'text-accent' : 'text-gray'}`} /> },\n ]}\n value={this.selectedValue}\n onChange={(newValue) => handleSelectBotAdmin(newValue)}\n size='small'\n />\n }\n {isFbOrIg && (\n <menu-list\n referenceSelector={'chat-header-menu'}\n iconName=\"Ellipsis\"\n position=\"bottom-end\"\n menuItems={[\n { label: 'ดึงประวัติแชท', value: 'sync_message', onClick: handleSyncChatMessage },\n ...(selectedChat?.channel === 'facebook' ? [{ label: 'ดึงป้ายกำกับ', value: 'sync_tags', onClick: handleSyncTags }] : []),\n ]}\n variant=\"none\"\n />\n )}\n </div>\n </div>\n </Host>\n );\n }\n}\n"],"version":3}