@ozdao/martyrs 0.2.481 → 0.2.482

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 (436) hide show
  1. package/README.md +4 -13
  2. package/dist/{Media-CKk33U4A.js → Media-JBERcJWj.js} +1 -1
  3. package/dist/{Media-B1ZP3D7B.cjs → Media-p7Q8ZAQM.cjs} +1 -1
  4. package/dist/{abac-XF1JVCLI.cjs → abac-6LjoG9u-.cjs} +107 -26
  5. package/dist/{abac-BuL5pUZ4.js → abac-Cf_9lCSh.js} +107 -26
  6. package/dist/globals.server.cjs +1 -1
  7. package/dist/globals.server.js +1 -1
  8. package/dist/{main-BhAiwmnI.js → main-AtCVQKF9.js} +2855 -4162
  9. package/dist/main-B-we7C0w.cjs +11 -0
  10. package/dist/martyrs/src/components/Button/Button.vue2.cjs.map +1 -1
  11. package/dist/martyrs/src/components/Button/Button.vue2.js.map +1 -1
  12. package/dist/martyrs/src/components/Checkbox/Checkbox.vue.cjs +28 -7
  13. package/dist/martyrs/src/components/Checkbox/Checkbox.vue.cjs.map +1 -1
  14. package/dist/martyrs/src/components/Checkbox/Checkbox.vue.js +29 -8
  15. package/dist/martyrs/src/components/Checkbox/Checkbox.vue.js.map +1 -1
  16. package/dist/martyrs/src/components/Chips/{Chips.vue.cjs → Chips.vue2.cjs} +7 -10
  17. package/dist/martyrs/src/components/Chips/Chips.vue2.cjs.map +1 -0
  18. package/dist/martyrs/src/components/Chips/{Chips.vue.js → Chips.vue2.js} +8 -11
  19. package/dist/martyrs/src/components/Chips/Chips.vue2.js.map +1 -0
  20. package/dist/martyrs/src/components/Feed/Carousel.vue.cjs +84 -0
  21. package/dist/martyrs/src/components/Feed/Carousel.vue.cjs.map +1 -0
  22. package/dist/martyrs/src/components/Feed/Carousel.vue.js +84 -0
  23. package/dist/martyrs/src/components/Feed/Carousel.vue.js.map +1 -0
  24. package/dist/martyrs/src/components/Feed/Feed.vue.cjs +4 -4
  25. package/dist/martyrs/src/components/Feed/Feed.vue.cjs.map +1 -1
  26. package/dist/martyrs/src/components/Feed/Feed.vue.js +4 -4
  27. package/dist/martyrs/src/components/Feed/Feed.vue.js.map +1 -1
  28. package/dist/martyrs/src/components/Field/Field.vue.cjs +2 -1
  29. package/dist/martyrs/src/components/Field/Field.vue.cjs.map +1 -1
  30. package/dist/martyrs/src/components/Field/Field.vue.js +2 -1
  31. package/dist/martyrs/src/components/Field/Field.vue.js.map +1 -1
  32. package/dist/martyrs/src/components/Menu/{Menu.vue.cjs → Menu.vue2.cjs} +2 -2
  33. package/dist/martyrs/src/components/Menu/Menu.vue2.cjs.map +1 -0
  34. package/dist/martyrs/src/components/Menu/{Menu.vue.js → Menu.vue2.js} +2 -2
  35. package/dist/martyrs/src/components/Menu/Menu.vue2.js.map +1 -0
  36. package/dist/martyrs/src/components/PhotoViewer/PhotoViewer.vue.cjs +203 -151
  37. package/dist/martyrs/src/components/PhotoViewer/PhotoViewer.vue.cjs.map +1 -1
  38. package/dist/martyrs/src/components/PhotoViewer/PhotoViewer.vue.js +204 -152
  39. package/dist/martyrs/src/components/PhotoViewer/PhotoViewer.vue.js.map +1 -1
  40. package/dist/martyrs/src/components/Popup/{Popup.vue.cjs → Popup.vue2.cjs} +2 -2
  41. package/dist/martyrs/src/components/Popup/Popup.vue2.cjs.map +1 -0
  42. package/dist/martyrs/src/components/Popup/{Popup.vue.js → Popup.vue2.js} +2 -2
  43. package/dist/martyrs/src/components/Popup/{Popup.vue.cjs.map → Popup.vue2.js.map} +1 -1
  44. package/dist/martyrs/src/components/Radio/Radio.vue.cjs +2 -2
  45. package/dist/martyrs/src/components/Radio/Radio.vue.cjs.map +1 -1
  46. package/dist/martyrs/src/components/Radio/Radio.vue.js +2 -2
  47. package/dist/martyrs/src/components/Radio/Radio.vue.js.map +1 -1
  48. package/dist/martyrs/src/components/Skeleton/Skeleton.vue.cjs +4 -3
  49. package/dist/martyrs/src/components/Skeleton/Skeleton.vue.cjs.map +1 -1
  50. package/dist/martyrs/src/components/Skeleton/Skeleton.vue.js +4 -3
  51. package/dist/martyrs/src/components/Skeleton/Skeleton.vue.js.map +1 -1
  52. package/dist/martyrs/src/components/Slider/{Slider.native.vue.cjs → Slider.vue.cjs} +22 -80
  53. package/dist/martyrs/src/components/Slider/Slider.vue.cjs.map +1 -0
  54. package/dist/martyrs/src/components/Slider/{Slider.native.vue.js → Slider.vue.js} +23 -81
  55. package/dist/martyrs/src/components/Slider/Slider.vue.js.map +1 -0
  56. package/dist/martyrs/src/components/Status/Status.vue.cjs.map +1 -1
  57. package/dist/martyrs/src/components/Status/Status.vue.js.map +1 -1
  58. package/dist/martyrs/src/components/Tooltip/Tooltip.vue2.cjs +4 -2
  59. package/dist/martyrs/src/components/Tooltip/Tooltip.vue2.cjs.map +1 -1
  60. package/dist/martyrs/src/components/Tooltip/Tooltip.vue2.js +4 -2
  61. package/dist/martyrs/src/components/Tooltip/Tooltip.vue2.js.map +1 -1
  62. package/dist/martyrs/src/modules/auth/views/components/pages/Profile.vue.cjs +3 -1
  63. package/dist/martyrs/src/modules/auth/views/components/pages/Profile.vue.cjs.map +1 -1
  64. package/dist/martyrs/src/modules/auth/views/components/pages/Profile.vue.js +4 -2
  65. package/dist/martyrs/src/modules/auth/views/components/pages/Profile.vue.js.map +1 -1
  66. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEdit.vue.cjs +22 -149
  67. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEdit.vue.cjs.map +1 -1
  68. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEdit.vue.js +24 -151
  69. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEdit.vue.js.map +1 -1
  70. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditAccount.vue.cjs +77 -0
  71. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditAccount.vue.cjs.map +1 -0
  72. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditAccount.vue.js +77 -0
  73. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditAccount.vue.js.map +1 -0
  74. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditProfile.vue.cjs +121 -0
  75. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditProfile.vue.cjs.map +1 -0
  76. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditProfile.vue.js +121 -0
  77. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditProfile.vue.js.map +1 -0
  78. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditSidebar.vue.cjs +38 -0
  79. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditSidebar.vue.cjs.map +1 -0
  80. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditSidebar.vue.js +38 -0
  81. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditSidebar.vue.js.map +1 -0
  82. package/dist/martyrs/src/modules/auth/views/router/users.cjs +23 -16
  83. package/dist/martyrs/src/modules/auth/views/router/users.cjs.map +1 -1
  84. package/dist/martyrs/src/modules/auth/views/router/users.js +23 -16
  85. package/dist/martyrs/src/modules/auth/views/router/users.js.map +1 -1
  86. package/dist/martyrs/src/modules/community/components/blocks/CardBlogpost.vue.cjs +1 -1
  87. package/dist/martyrs/src/modules/community/components/blocks/CardBlogpost.vue.js +1 -1
  88. package/dist/martyrs/src/modules/community/components/blocks/FooterBlogpost.vue.cjs +3 -3
  89. package/dist/martyrs/src/modules/community/components/blocks/FooterBlogpost.vue.cjs.map +1 -1
  90. package/dist/martyrs/src/modules/community/components/blocks/FooterBlogpost.vue.js +3 -3
  91. package/dist/martyrs/src/modules/community/components/blocks/FooterBlogpost.vue.js.map +1 -1
  92. package/dist/martyrs/src/modules/community/components/layouts/Community.vue.js +6 -6
  93. package/dist/martyrs/src/modules/community/components/pages/BlogPost.vue.cjs +5 -4
  94. package/dist/martyrs/src/modules/community/components/pages/BlogPost.vue.cjs.map +1 -1
  95. package/dist/martyrs/src/modules/community/components/pages/BlogPost.vue.js +5 -4
  96. package/dist/martyrs/src/modules/community/components/pages/BlogPost.vue.js.map +1 -1
  97. package/dist/martyrs/src/modules/community/components/pages/CreateBlogPost.vue.cjs +1 -1
  98. package/dist/martyrs/src/modules/community/components/pages/CreateBlogPost.vue.js +1 -1
  99. package/dist/martyrs/src/modules/community/components/sections/Comment.vue.cjs +92 -62
  100. package/dist/martyrs/src/modules/community/components/sections/Comment.vue.cjs.map +1 -1
  101. package/dist/martyrs/src/modules/community/components/sections/Comment.vue.js +93 -63
  102. package/dist/martyrs/src/modules/community/components/sections/Comment.vue.js.map +1 -1
  103. package/dist/martyrs/src/modules/community/components/sections/Comments.vue.cjs +82 -53
  104. package/dist/martyrs/src/modules/community/components/sections/Comments.vue.cjs.map +1 -1
  105. package/dist/martyrs/src/modules/community/components/sections/Comments.vue.js +82 -53
  106. package/dist/martyrs/src/modules/community/components/sections/Comments.vue.js.map +1 -1
  107. package/dist/martyrs/src/modules/community/components/sections/HotPosts.vue.cjs +2 -6
  108. package/dist/martyrs/src/modules/community/components/sections/HotPosts.vue.cjs.map +1 -1
  109. package/dist/martyrs/src/modules/community/components/sections/HotPosts.vue.js +2 -6
  110. package/dist/martyrs/src/modules/community/components/sections/HotPosts.vue.js.map +1 -1
  111. package/dist/martyrs/src/modules/events/components/blocks/CardEvent.vue.cjs +1 -1
  112. package/dist/martyrs/src/modules/events/components/blocks/CardEvent.vue.js +1 -1
  113. package/dist/martyrs/src/modules/events/components/pages/EditEvent.vue.cjs +1 -1
  114. package/dist/martyrs/src/modules/events/components/pages/EditEvent.vue.js +1 -1
  115. package/dist/martyrs/src/modules/events/components/pages/EditEventTickets.vue.cjs +1 -1
  116. package/dist/martyrs/src/modules/events/components/pages/EditEventTickets.vue.js +1 -1
  117. package/dist/martyrs/src/modules/events/components/pages/Event.vue.cjs +1 -1
  118. package/dist/martyrs/src/modules/events/components/pages/Event.vue.js +1 -1
  119. package/dist/martyrs/src/modules/events/components/pages/Events.vue.cjs +1 -1
  120. package/dist/martyrs/src/modules/events/components/pages/Events.vue.js +1 -1
  121. package/dist/martyrs/src/modules/events/components/sections/EventsHot.vue.cjs +3 -9
  122. package/dist/martyrs/src/modules/events/components/sections/EventsHot.vue.cjs.map +1 -1
  123. package/dist/martyrs/src/modules/events/components/sections/EventsHot.vue.js +3 -9
  124. package/dist/martyrs/src/modules/events/components/sections/EventsHot.vue.js.map +1 -1
  125. package/dist/martyrs/src/modules/gallery/components/pages/Gallery.vue.cjs +1 -1
  126. package/dist/martyrs/src/modules/gallery/components/pages/Gallery.vue.js +5 -5
  127. package/dist/martyrs/src/modules/gallery/components/sections/BackofficeGallery.vue.cjs +2 -2
  128. package/dist/martyrs/src/modules/gallery/components/sections/BackofficeGallery.vue.js +11 -11
  129. package/dist/martyrs/src/modules/globals/globals.client.cjs +2 -0
  130. package/dist/martyrs/src/modules/globals/globals.client.cjs.map +1 -1
  131. package/dist/martyrs/src/modules/globals/globals.client.js +2 -0
  132. package/dist/martyrs/src/modules/globals/globals.client.js.map +1 -1
  133. package/dist/martyrs/src/modules/globals/views/components/blocks/AlertDialog.vue.cjs +1 -1
  134. package/dist/martyrs/src/modules/globals/views/components/blocks/AlertDialog.vue.js +1 -1
  135. package/dist/martyrs/src/modules/globals/views/components/blocks/CardHeader.vue.cjs +1 -1
  136. package/dist/martyrs/src/modules/globals/views/components/blocks/CardHeader.vue.cjs.map +1 -1
  137. package/dist/martyrs/src/modules/globals/views/components/blocks/CardHeader.vue.js +1 -1
  138. package/dist/martyrs/src/modules/globals/views/components/blocks/CardHeader.vue.js.map +1 -1
  139. package/dist/martyrs/src/modules/globals/views/components/blocks/PopupAuth.vue.cjs +84 -0
  140. package/dist/martyrs/src/modules/globals/views/components/blocks/PopupAuth.vue.cjs.map +1 -0
  141. package/dist/martyrs/src/modules/globals/views/components/blocks/PopupAuth.vue.js +84 -0
  142. package/dist/martyrs/src/modules/globals/views/components/blocks/PopupAuth.vue.js.map +1 -0
  143. package/dist/martyrs/src/modules/globals/views/components/blocks/PopupDateSelector.vue.cjs +1 -1
  144. package/dist/martyrs/src/modules/globals/views/components/blocks/PopupDateSelector.vue.js +1 -1
  145. package/dist/martyrs/src/modules/globals/views/components/layouts/Client.vue.cjs +1 -1
  146. package/dist/martyrs/src/modules/globals/views/components/layouts/Client.vue.js +1 -1
  147. package/dist/martyrs/src/modules/globals/views/mixins/mixins.cjs +17 -0
  148. package/dist/martyrs/src/modules/globals/views/mixins/mixins.cjs.map +1 -1
  149. package/dist/martyrs/src/modules/globals/views/mixins/mixins.js +17 -0
  150. package/dist/martyrs/src/modules/globals/views/mixins/mixins.js.map +1 -1
  151. package/dist/martyrs/src/modules/globals/views/plugins/popup.auth.plugin.cjs +70 -0
  152. package/dist/martyrs/src/modules/globals/views/plugins/popup.auth.plugin.cjs.map +1 -0
  153. package/dist/martyrs/src/modules/globals/views/plugins/popup.auth.plugin.js +70 -0
  154. package/dist/martyrs/src/modules/globals/views/plugins/popup.auth.plugin.js.map +1 -0
  155. package/dist/martyrs/src/modules/icons/entities/IconList.vue.cjs +35 -0
  156. package/dist/martyrs/src/modules/icons/entities/IconList.vue.cjs.map +1 -0
  157. package/dist/martyrs/src/modules/icons/entities/IconList.vue.js +35 -0
  158. package/dist/martyrs/src/modules/icons/entities/IconList.vue.js.map +1 -0
  159. package/dist/martyrs/src/modules/icons/navigation/IconCheck.vue.cjs +1 -3
  160. package/dist/martyrs/src/modules/icons/navigation/IconCheck.vue.cjs.map +1 -1
  161. package/dist/martyrs/src/modules/icons/navigation/IconCheck.vue.js +1 -3
  162. package/dist/martyrs/src/modules/icons/navigation/IconCheck.vue.js.map +1 -1
  163. package/dist/martyrs/src/modules/icons/navigation/IconDoubleCheck.vue.cjs +1 -3
  164. package/dist/martyrs/src/modules/icons/navigation/IconDoubleCheck.vue.cjs.map +1 -1
  165. package/dist/martyrs/src/modules/icons/navigation/IconDoubleCheck.vue.js +1 -3
  166. package/dist/martyrs/src/modules/icons/navigation/IconDoubleCheck.vue.js.map +1 -1
  167. package/dist/martyrs/src/modules/icons/navigation/IconLike.vue.cjs +1 -3
  168. package/dist/martyrs/src/modules/icons/navigation/IconLike.vue.cjs.map +1 -1
  169. package/dist/martyrs/src/modules/icons/navigation/IconLike.vue.js +1 -3
  170. package/dist/martyrs/src/modules/icons/navigation/IconLike.vue.js.map +1 -1
  171. package/dist/martyrs/src/modules/icons/navigation/IconMute.vue.cjs +1 -3
  172. package/dist/martyrs/src/modules/icons/navigation/IconMute.vue.cjs.map +1 -1
  173. package/dist/martyrs/src/modules/icons/navigation/IconMute.vue.js +1 -3
  174. package/dist/martyrs/src/modules/icons/navigation/IconMute.vue.js.map +1 -1
  175. package/dist/martyrs/src/modules/icons/navigation/IconPause.vue.cjs +1 -3
  176. package/dist/martyrs/src/modules/icons/navigation/IconPause.vue.cjs.map +1 -1
  177. package/dist/martyrs/src/modules/icons/navigation/IconPause.vue.js +1 -3
  178. package/dist/martyrs/src/modules/icons/navigation/IconPause.vue.js.map +1 -1
  179. package/dist/martyrs/src/modules/icons/navigation/IconPlay.vue.cjs +21 -20
  180. package/dist/martyrs/src/modules/icons/navigation/IconPlay.vue.cjs.map +1 -1
  181. package/dist/martyrs/src/modules/icons/navigation/IconPlay.vue.js +21 -20
  182. package/dist/martyrs/src/modules/icons/navigation/IconPlay.vue.js.map +1 -1
  183. package/dist/martyrs/src/modules/icons/navigation/IconRefresh.vue.cjs +1 -3
  184. package/dist/martyrs/src/modules/icons/navigation/IconRefresh.vue.cjs.map +1 -1
  185. package/dist/martyrs/src/modules/icons/navigation/IconRefresh.vue.js +1 -3
  186. package/dist/martyrs/src/modules/icons/navigation/IconRefresh.vue.js.map +1 -1
  187. package/dist/martyrs/src/modules/icons/navigation/IconShuffle.vue.cjs +6 -13
  188. package/dist/martyrs/src/modules/icons/navigation/IconShuffle.vue.cjs.map +1 -1
  189. package/dist/martyrs/src/modules/icons/navigation/IconShuffle.vue.js +6 -13
  190. package/dist/martyrs/src/modules/icons/navigation/IconShuffle.vue.js.map +1 -1
  191. package/dist/martyrs/src/modules/icons/navigation/IconUnMute.vue.cjs +1 -3
  192. package/dist/martyrs/src/modules/icons/navigation/IconUnMute.vue.cjs.map +1 -1
  193. package/dist/martyrs/src/modules/icons/navigation/IconUnMute.vue.js +1 -3
  194. package/dist/martyrs/src/modules/icons/navigation/IconUnMute.vue.js.map +1 -1
  195. package/dist/martyrs/src/modules/icons/navigation/IconVolume.vue.cjs +1 -3
  196. package/dist/martyrs/src/modules/icons/navigation/IconVolume.vue.cjs.map +1 -1
  197. package/dist/martyrs/src/modules/icons/navigation/IconVolume.vue.js +1 -3
  198. package/dist/martyrs/src/modules/icons/navigation/IconVolume.vue.js.map +1 -1
  199. package/dist/martyrs/src/modules/icons/pages/IconsPage.vue.cjs +1 -3
  200. package/dist/martyrs/src/modules/icons/pages/IconsPage.vue.cjs.map +1 -1
  201. package/dist/martyrs/src/modules/icons/pages/IconsPage.vue.js +41 -43
  202. package/dist/martyrs/src/modules/icons/pages/IconsPage.vue.js.map +1 -1
  203. package/dist/martyrs/src/modules/notifications/components/blocks/NotificationItem.vue.cjs +8 -8
  204. package/dist/martyrs/src/modules/notifications/components/blocks/NotificationItem.vue.cjs.map +1 -1
  205. package/dist/martyrs/src/modules/notifications/components/blocks/NotificationItem.vue.js +8 -8
  206. package/dist/martyrs/src/modules/notifications/components/blocks/NotificationItem.vue.js.map +1 -1
  207. package/dist/martyrs/src/modules/notifications/components/elements/NotificationBadge.vue.cjs +50 -51
  208. package/dist/martyrs/src/modules/notifications/components/elements/NotificationBadge.vue.cjs.map +1 -1
  209. package/dist/martyrs/src/modules/notifications/components/elements/NotificationBadge.vue.js +51 -52
  210. package/dist/martyrs/src/modules/notifications/components/elements/NotificationBadge.vue.js.map +1 -1
  211. package/dist/martyrs/src/modules/orders/components/pages/OrderBackoffice.vue.cjs +1 -1
  212. package/dist/martyrs/src/modules/orders/components/pages/OrderBackoffice.vue.js +1 -1
  213. package/dist/martyrs/src/modules/orders/components/pages/OrderCreateBackoffice.vue.cjs +1 -1
  214. package/dist/martyrs/src/modules/orders/components/pages/OrderCreateBackoffice.vue.js +1 -1
  215. package/dist/martyrs/src/modules/organizations/components/blocks/CardOrganization.vue.cjs +1 -1
  216. package/dist/martyrs/src/modules/organizations/components/blocks/CardOrganization.vue.js +1 -1
  217. package/dist/martyrs/src/modules/organizations/components/pages/DepartmentEdit.vue.cjs +1 -1
  218. package/dist/martyrs/src/modules/organizations/components/pages/DepartmentEdit.vue.js +1 -1
  219. package/dist/martyrs/src/modules/organizations/components/pages/Members.vue.cjs +2 -2
  220. package/dist/martyrs/src/modules/organizations/components/pages/Members.vue.js +2 -2
  221. package/dist/martyrs/src/modules/organizations/components/pages/Organization.vue.cjs +1 -1
  222. package/dist/martyrs/src/modules/organizations/components/pages/Organization.vue.js +1 -1
  223. package/dist/martyrs/src/modules/organizations/components/pages/OrganizationBackoffice.vue.cjs +1 -1
  224. package/dist/martyrs/src/modules/organizations/components/pages/OrganizationBackoffice.vue.js +1 -1
  225. package/dist/martyrs/src/modules/organizations/components/pages/OrganizationEdit.vue.cjs +1 -1
  226. package/dist/martyrs/src/modules/organizations/components/pages/OrganizationEdit.vue.js +1 -1
  227. package/dist/martyrs/src/modules/organizations/components/sections/DetailsTabSection.vue.cjs +1 -1
  228. package/dist/martyrs/src/modules/organizations/components/sections/DetailsTabSection.vue.js +1 -1
  229. package/dist/martyrs/src/modules/organizations/components/sections/Documents.vue.cjs +1 -1
  230. package/dist/martyrs/src/modules/organizations/components/sections/Documents.vue.js +1 -1
  231. package/dist/martyrs/src/modules/organizations/configs/navigation.organization.config.cjs +7 -4
  232. package/dist/martyrs/src/modules/organizations/configs/navigation.organization.config.cjs.map +1 -1
  233. package/dist/martyrs/src/modules/organizations/configs/navigation.organization.config.js +18 -15
  234. package/dist/martyrs/src/modules/organizations/configs/navigation.organization.config.js.map +1 -1
  235. package/dist/martyrs/src/modules/organizations/router/organizations.cjs +1 -1
  236. package/dist/martyrs/src/modules/organizations/router/organizations.js +1 -1
  237. package/dist/martyrs/src/modules/pages/views/components/partials/SidebarPages.vue.cjs +1 -1
  238. package/dist/martyrs/src/modules/pages/views/components/partials/SidebarPages.vue.js +1 -1
  239. package/dist/martyrs/src/modules/products/components/blocks/CardProduct.vue.cjs +7 -2
  240. package/dist/martyrs/src/modules/products/components/blocks/CardProduct.vue.cjs.map +1 -1
  241. package/dist/martyrs/src/modules/products/components/blocks/CardProduct.vue.js +8 -3
  242. package/dist/martyrs/src/modules/products/components/blocks/CardProduct.vue.js.map +1 -1
  243. package/dist/martyrs/src/modules/products/components/blocks/ProductDiscounts.vue.cjs +12 -13
  244. package/dist/martyrs/src/modules/products/components/blocks/ProductDiscounts.vue.cjs.map +1 -1
  245. package/dist/martyrs/src/modules/products/components/blocks/ProductDiscounts.vue.js +13 -14
  246. package/dist/martyrs/src/modules/products/components/blocks/ProductDiscounts.vue.js.map +1 -1
  247. package/dist/martyrs/src/modules/products/components/blocks/ProductImages.vue.cjs +33 -24
  248. package/dist/martyrs/src/modules/products/components/blocks/ProductImages.vue.cjs.map +1 -1
  249. package/dist/martyrs/src/modules/products/components/blocks/ProductImages.vue.js +36 -27
  250. package/dist/martyrs/src/modules/products/components/blocks/ProductImages.vue.js.map +1 -1
  251. package/dist/martyrs/src/modules/products/components/blocks/ProductVariants.vue.cjs +4 -4
  252. package/dist/martyrs/src/modules/products/components/blocks/ProductVariants.vue.cjs.map +1 -1
  253. package/dist/martyrs/src/modules/products/components/blocks/ProductVariants.vue.js +4 -4
  254. package/dist/martyrs/src/modules/products/components/blocks/ProductVariants.vue.js.map +1 -1
  255. package/dist/martyrs/src/modules/products/components/elements/Price.vue.cjs +7 -5
  256. package/dist/martyrs/src/modules/products/components/elements/Price.vue.cjs.map +1 -1
  257. package/dist/martyrs/src/modules/products/components/elements/Price.vue.js +7 -5
  258. package/dist/martyrs/src/modules/products/components/elements/Price.vue.js.map +1 -1
  259. package/dist/martyrs/src/modules/products/components/pages/CategoryEdit.vue.cjs +1 -1
  260. package/dist/martyrs/src/modules/products/components/pages/CategoryEdit.vue.js +1 -1
  261. package/dist/martyrs/src/modules/products/components/pages/LeftoverEdit.vue.cjs +1 -1
  262. package/dist/martyrs/src/modules/products/components/pages/LeftoverEdit.vue.js +1 -1
  263. package/dist/martyrs/src/modules/products/components/pages/Leftovers.vue.cjs +2 -2
  264. package/dist/martyrs/src/modules/products/components/pages/Leftovers.vue.js +1 -1
  265. package/dist/martyrs/src/modules/products/components/pages/Product.vue.cjs +57 -40
  266. package/dist/martyrs/src/modules/products/components/pages/Product.vue.cjs.map +1 -1
  267. package/dist/martyrs/src/modules/products/components/pages/Product.vue.js +59 -42
  268. package/dist/martyrs/src/modules/products/components/pages/Product.vue.js.map +1 -1
  269. package/dist/martyrs/src/modules/products/components/pages/ProductEdit.vue.cjs +104 -84
  270. package/dist/martyrs/src/modules/products/components/pages/ProductEdit.vue.cjs.map +1 -1
  271. package/dist/martyrs/src/modules/products/components/pages/ProductEdit.vue.js +106 -86
  272. package/dist/martyrs/src/modules/products/components/pages/ProductEdit.vue.js.map +1 -1
  273. package/dist/martyrs/src/modules/products/components/sections/EditAttributes.vue.cjs +1 -1
  274. package/dist/martyrs/src/modules/products/components/sections/EditAttributes.vue.js +1 -1
  275. package/dist/martyrs/src/modules/products/components/sections/EditDiscounts.vue.cjs +1 -1
  276. package/dist/martyrs/src/modules/products/components/sections/EditDiscounts.vue.js +1 -1
  277. package/dist/martyrs/src/modules/products/components/sections/EditIngredients.vue.cjs +1 -1
  278. package/dist/martyrs/src/modules/products/components/sections/EditIngredients.vue.js +1 -1
  279. package/dist/martyrs/src/modules/products/components/sections/EditRecommended.vue.cjs +145 -0
  280. package/dist/martyrs/src/modules/products/components/sections/EditRecommended.vue.cjs.map +1 -0
  281. package/dist/martyrs/src/modules/products/components/sections/EditRecommended.vue.js +145 -0
  282. package/dist/martyrs/src/modules/products/components/sections/EditRecommended.vue.js.map +1 -0
  283. package/dist/martyrs/src/modules/products/components/sections/EditVariants.vue.cjs +1 -1
  284. package/dist/martyrs/src/modules/products/components/sections/EditVariants.vue.js +1 -1
  285. package/dist/martyrs/src/modules/products/components/sections/ProductConfigurator.vue.cjs +45 -30
  286. package/dist/martyrs/src/modules/products/components/sections/ProductConfigurator.vue.cjs.map +1 -1
  287. package/dist/martyrs/src/modules/products/components/sections/ProductConfigurator.vue.js +50 -35
  288. package/dist/martyrs/src/modules/products/components/sections/ProductConfigurator.vue.js.map +1 -1
  289. package/dist/martyrs/src/modules/products/components/sections/ProductsPopular.vue.cjs +43 -0
  290. package/dist/martyrs/src/modules/products/components/sections/ProductsPopular.vue.cjs.map +1 -0
  291. package/dist/martyrs/src/modules/products/components/sections/ProductsPopular.vue.js +43 -0
  292. package/dist/martyrs/src/modules/products/components/sections/ProductsPopular.vue.js.map +1 -0
  293. package/dist/martyrs/src/modules/products/components/sections/ProductsRecommended.vue.cjs +131 -0
  294. package/dist/martyrs/src/modules/products/components/sections/ProductsRecommended.vue.cjs.map +1 -0
  295. package/dist/martyrs/src/modules/products/components/sections/ProductsRecommended.vue.js +131 -0
  296. package/dist/martyrs/src/modules/products/components/sections/ProductsRecommended.vue.js.map +1 -0
  297. package/dist/martyrs/src/modules/products/products.client.cjs +3 -3
  298. package/dist/martyrs/src/modules/products/products.client.cjs.map +1 -1
  299. package/dist/martyrs/src/modules/products/products.client.js +3 -3
  300. package/dist/martyrs/src/modules/products/products.client.js.map +1 -1
  301. package/dist/martyrs/src/modules/products/store/products.cjs +4 -0
  302. package/dist/martyrs/src/modules/products/store/products.cjs.map +1 -1
  303. package/dist/martyrs/src/modules/products/store/products.js +4 -0
  304. package/dist/martyrs/src/modules/products/store/products.js.map +1 -1
  305. package/dist/martyrs/src/modules/rents/views/components/pages/RentsEdit.vue.cjs +1 -1
  306. package/dist/martyrs/src/modules/rents/views/components/pages/RentsEdit.vue.js +1 -1
  307. package/dist/martyrs/src/modules/reports/components/sections/FormReport.vue.cjs +1 -1
  308. package/dist/martyrs/src/modules/reports/components/sections/FormReport.vue.js +1 -1
  309. package/dist/martyrs/src/modules/spots/components/blocks/CardSpot.vue.cjs +1 -1
  310. package/dist/martyrs/src/modules/spots/components/blocks/CardSpot.vue.js +1 -1
  311. package/dist/martyrs/src/modules/spots/components/pages/SpotEdit.vue.cjs +1 -1
  312. package/dist/martyrs/src/modules/spots/components/pages/SpotEdit.vue.js +1 -1
  313. package/dist/martyrs/src/modules/spots/components/sections/WorktimeEdit.vue.cjs +1 -1
  314. package/dist/martyrs/src/modules/spots/components/sections/WorktimeEdit.vue.js +1 -1
  315. package/dist/martyrs/src/modules/wallet/views/components/pages/Wallet.vue.cjs +2 -2
  316. package/dist/martyrs/src/modules/wallet/views/components/pages/Wallet.vue.js +2 -2
  317. package/dist/martyrs.cjs.js +1 -1
  318. package/dist/martyrs.css +1 -1
  319. package/dist/martyrs.es.js +1 -1
  320. package/dist/node_modules/.pnpm/qrcode@1.5.4/node_modules/qrcode/lib/core/utils.cjs +1 -1
  321. package/dist/node_modules/.pnpm/qrcode@1.5.4/node_modules/qrcode/lib/core/utils.js +1 -1
  322. package/dist/node_modules/.pnpm/qrcode@1.5.4/node_modules/qrcode/lib/renderer/utils.cjs +1 -1
  323. package/dist/node_modules/.pnpm/qrcode@1.5.4/node_modules/qrcode/lib/renderer/utils.js +1 -1
  324. package/dist/organizations.server.cjs +1 -1
  325. package/dist/organizations.server.js +1 -1
  326. package/dist/products.server.cjs +111 -34
  327. package/dist/products.server.js +111 -34
  328. package/dist/style.css +196 -170
  329. package/package.json +1 -1
  330. package/src/.martyrs/chunks.json +325 -0
  331. package/src/.martyrs/filemap.json +6802 -0
  332. package/src/.martyrs/semantic-analysis.json +307 -0
  333. package/src/.martyrs/toc.json +14 -0
  334. package/src/components/Button/Button.vue +2 -2
  335. package/src/components/Checkbox/Checkbox.vue +28 -16
  336. package/src/components/Chips/Chips.vue +4 -4
  337. package/src/components/Feed/Carousel.vue +72 -0
  338. package/src/components/Feed/Feed.vue +2 -2
  339. package/src/components/Field/Field.vue +1 -0
  340. package/src/components/PhotoViewer/PhotoViewer.vue +307 -220
  341. package/src/components/Radio/Radio.vue +2 -10
  342. package/src/components/Skeleton/Skeleton.vue +9 -12
  343. package/src/components/Slider/Slider.vue +220 -100
  344. package/src/components/Status/Status.vue +0 -1
  345. package/src/components/Tooltip/Tooltip.vue +2 -2
  346. package/src/modules/auth/views/components/pages/Profile.vue +1 -1
  347. package/src/modules/auth/views/components/pages/ProfileEdit.old.vue +189 -0
  348. package/src/modules/auth/views/components/pages/ProfileEdit.vue +19 -182
  349. package/src/modules/auth/views/components/pages/ProfileEditAccount.vue +72 -0
  350. package/src/modules/auth/views/components/pages/ProfileEditProfile.vue +110 -0
  351. package/src/modules/auth/views/components/pages/ProfileEditSidebar.vue +28 -0
  352. package/src/modules/auth/views/router/users.js +23 -12
  353. package/src/modules/community/components/blocks/FooterBlogpost.vue +3 -3
  354. package/src/modules/community/components/pages/BlogPost.vue +2 -1
  355. package/src/modules/community/components/sections/Comment.vue +161 -57
  356. package/src/modules/community/components/sections/Comments.vue +120 -63
  357. package/src/modules/community/components/sections/HotPosts.vue +7 -7
  358. package/src/modules/events/components/sections/EventsHot.vue +26 -33
  359. package/src/modules/globals/controllers/classes/abac/abac.core.js +3 -1
  360. package/src/modules/globals/controllers/classes/abac/abac.fields.js +126 -42
  361. package/src/modules/globals/controllers/classes/abac/v2/abac-core-fixed.js +313 -0
  362. package/src/modules/globals/controllers/classes/abac/v2/abac-express-fixed.js +276 -0
  363. package/src/modules/globals/controllers/classes/abac/v2/abac-fields-fixed.js +422 -0
  364. package/src/modules/globals/controllers/classes/abac/v2/abac-main-fixed.js +295 -0
  365. package/src/modules/globals/controllers/classes/abac/v2/abac-policies-fixed.js +316 -0
  366. package/src/modules/globals/controllers/classes/abac/v2/abac-ws-fixed.js +237 -0
  367. package/src/modules/globals/globals.client.js +2 -0
  368. package/src/modules/globals/views/components/blocks/CardFooter.vue +3 -3
  369. package/src/modules/globals/views/components/blocks/CardHeader.vue +1 -1
  370. package/src/modules/globals/views/components/blocks/PopupAuth.vue +66 -0
  371. package/src/modules/globals/views/mixins/mixins.js +37 -17
  372. package/src/modules/globals/views/plugins/popup.auth.plugin.js +77 -0
  373. package/src/modules/icons/entities/IconList.vue +14 -0
  374. package/src/modules/icons/navigation/IconCheck.vue +1 -3
  375. package/src/modules/icons/navigation/IconDoubleCheck.vue +1 -3
  376. package/src/modules/icons/navigation/IconLike.vue +1 -3
  377. package/src/modules/icons/navigation/IconMute.vue +1 -3
  378. package/src/modules/icons/navigation/IconPause.vue +1 -3
  379. package/src/modules/icons/navigation/IconPlay.vue +12 -15
  380. package/src/modules/icons/navigation/IconRefresh.vue +1 -3
  381. package/src/modules/icons/navigation/IconShuffle.vue +11 -26
  382. package/src/modules/icons/navigation/IconUnMute.vue +1 -3
  383. package/src/modules/icons/navigation/IconVolume.vue +1 -3
  384. package/src/modules/icons/pages/IconsPage.vue +0 -2
  385. package/src/modules/music/components/pages/AlbumDetail.vue +2 -2
  386. package/src/modules/music/components/pages/PlaylistDetail.vue +2 -2
  387. package/src/modules/music/components/pages/TrackDetail.vue +1 -1
  388. package/src/modules/music/components/player/MusicPlayer.vue +2 -2
  389. package/src/modules/notifications/components/blocks/NotificationItem.vue +6 -51
  390. package/src/modules/notifications/components/elements/NotificationBadge.vue +53 -97
  391. package/src/modules/organizations/configs/navigation.organization.config.js +8 -4
  392. package/src/modules/products/components/blocks/CardProduct.vue +8 -2
  393. package/src/modules/products/components/blocks/ProductDiscounts.vue +3 -4
  394. package/src/modules/products/components/blocks/ProductImages.vue +32 -23
  395. package/src/modules/products/components/blocks/ProductVariants.vue +6 -4
  396. package/src/modules/products/components/elements/Price.vue +3 -3
  397. package/src/modules/products/components/pages/Product.vue +32 -26
  398. package/src/modules/products/components/pages/ProductEdit.vue +95 -72
  399. package/src/modules/products/components/sections/EditRecommended.vue +131 -0
  400. package/src/modules/products/components/sections/ProductConfigurator.vue +35 -21
  401. package/src/modules/products/components/sections/ProductsPopular.vue +44 -0
  402. package/src/modules/products/components/sections/ProductsRecommended.vue +134 -0
  403. package/src/modules/products/controllers/configs/products.lookup.config.js +20 -15
  404. package/src/modules/products/controllers/products.controller.js +7 -22
  405. package/src/modules/products/models/category.model.js +28 -1
  406. package/src/modules/products/models/leftover.model.js +32 -0
  407. package/src/modules/products/models/product.model.js +37 -1
  408. package/src/modules/products/models/variant.model.js +35 -0
  409. package/src/modules/products/products.client.js +3 -3
  410. package/src/modules/products/routes/products.routes.js +1 -0
  411. package/src/modules/products/store/products.js +4 -0
  412. package/src/styles/base/all.scss +0 -38
  413. package/src/styles/base/shadow_transitions_hover_refactor.scss +20 -51
  414. package/src/styles/config.scss +51 -1
  415. package/dist/main-C75EcBpE.cjs +0 -11
  416. package/dist/martyrs/src/components/Chips/Chips.vue.cjs.map +0 -1
  417. package/dist/martyrs/src/components/Chips/Chips.vue.js.map +0 -1
  418. package/dist/martyrs/src/components/Menu/Menu.vue.cjs.map +0 -1
  419. package/dist/martyrs/src/components/Menu/Menu.vue.js.map +0 -1
  420. package/dist/martyrs/src/components/Popup/Popup.vue.js.map +0 -1
  421. package/dist/martyrs/src/components/Slider/Slider.native.vue.cjs.map +0 -1
  422. package/dist/martyrs/src/components/Slider/Slider.native.vue.js.map +0 -1
  423. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEdit.vue2.cjs +0 -2
  424. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEdit.vue2.cjs.map +0 -1
  425. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEdit.vue2.js +0 -2
  426. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEdit.vue2.js.map +0 -1
  427. package/dist/martyrs/src/modules/icons/navigation/IconHeart.vue.cjs +0 -34
  428. package/dist/martyrs/src/modules/icons/navigation/IconHeart.vue.cjs.map +0 -1
  429. package/dist/martyrs/src/modules/icons/navigation/IconHeart.vue.js +0 -34
  430. package/dist/martyrs/src/modules/icons/navigation/IconHeart.vue.js.map +0 -1
  431. package/dist/martyrs/src/modules/products/components/sections/PopularProducts.vue.cjs +0 -124
  432. package/dist/martyrs/src/modules/products/components/sections/PopularProducts.vue.cjs.map +0 -1
  433. package/dist/martyrs/src/modules/products/components/sections/PopularProducts.vue.js +0 -124
  434. package/dist/martyrs/src/modules/products/components/sections/PopularProducts.vue.js.map +0 -1
  435. package/src/components/Slider/Slider.native.vue +0 -313
  436. package/src/modules/products/components/sections/PopularProducts.vue +0 -156
@@ -4,12 +4,12 @@ const vue = require("vue");
4
4
  const _pluginVue_exportHelper = require("../../../../../../_virtual/_plugin-vue_export-helper.cjs");
5
5
  const _hoisted_1 = { class: "notification-icon" };
6
6
  const _hoisted_2 = { class: "notification-content" };
7
- const _hoisted_3 = { class: "notification-title" };
8
- const _hoisted_4 = { class: "notification-body" };
9
- const _hoisted_5 = { class: "notification-time" };
7
+ const _hoisted_3 = { class: "p-medium t-medium mn-b-small" };
8
+ const _hoisted_4 = { class: "p-small mn-b-small" };
9
+ const _hoisted_5 = { class: "pd-thin w-max radius-thin bg-white" };
10
10
  const _hoisted_6 = {
11
11
  key: 0,
12
- class: "unread-indicator"
12
+ class: "flex-child-default unread-indicator"
13
13
  };
14
14
  const _sfc_main = {
15
15
  __name: "NotificationItem",
@@ -62,20 +62,20 @@ const _sfc_main = {
62
62
  };
63
63
  return (_ctx, _cache) => {
64
64
  return vue.openBlock(), vue.createElementBlock("div", {
65
- class: vue.normalizeClass(["notification-item", { unread: isUnread.value }]),
65
+ class: vue.normalizeClass(["notification-item gap-thin flex pd-small radius-small bg-light", { "bg-second-small": isUnread.value }]),
66
66
  onClick: handleClick
67
67
  }, [
68
68
  vue.createElementVNode("div", _hoisted_1, vue.toDisplayString(notificationIcon.value), 1),
69
69
  vue.createElementVNode("div", _hoisted_2, [
70
- vue.createElementVNode("h3", _hoisted_3, vue.toDisplayString(__props.notification.title), 1),
70
+ vue.createElementVNode("p", _hoisted_3, vue.toDisplayString(__props.notification.title), 1),
71
71
  vue.createElementVNode("p", _hoisted_4, vue.toDisplayString(__props.notification.body), 1),
72
- vue.createElementVNode("span", _hoisted_5, vue.toDisplayString(formattedDate.value), 1)
72
+ vue.createElementVNode("p", _hoisted_5, vue.toDisplayString(formattedDate.value), 1)
73
73
  ]),
74
74
  isUnread.value ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_6)) : vue.createCommentVNode("", true)
75
75
  ], 2);
76
76
  };
77
77
  }
78
78
  };
79
- const NotificationItem = /* @__PURE__ */ _pluginVue_exportHelper.default(_sfc_main, [["__scopeId", "data-v-c57c48a6"]]);
79
+ const NotificationItem = /* @__PURE__ */ _pluginVue_exportHelper.default(_sfc_main, [["__scopeId", "data-v-8aa96de9"]]);
80
80
  exports.default = NotificationItem;
81
81
  //# sourceMappingURL=NotificationItem.vue.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"NotificationItem.vue.cjs","sources":["../../../../../../../src/modules/notifications/components/blocks/NotificationItem.vue"],"sourcesContent":["<script setup>\nimport { computed } from 'vue';\n\n// Props\nconst props = defineProps({\n notification: {\n type: Object,\n required: true\n }\n});\n\n// Compute if notification is unread\nconst isUnread = computed(() => props.notification.status !== 'read');\n\n// Format date\nconst formattedDate = computed(() => {\n const date = new Date(props.notification.createdAt);\n const now = new Date();\n const diffMs = now - date;\n const diffSec = Math.floor(diffMs / 1000);\n const diffMin = Math.floor(diffSec / 60);\n const diffHours = Math.floor(diffMin / 60);\n const diffDays = Math.floor(diffHours / 24);\n \n if (diffSec < 60) {\n return 'Just now';\n } else if (diffMin < 60) {\n return `${diffMin}m ago`;\n } else if (diffHours < 24) {\n return `${diffHours}h ago`;\n } else if (diffDays < 7) {\n return `${diffDays}d ago`;\n } else {\n return date.toLocaleDateString();\n }\n});\n\n// Get icon based on notification type\nconst notificationIcon = computed(() => {\n switch (props.notification.type) {\n case 'alert':\n return '⚠️';\n case 'success':\n return '✅';\n case 'error':\n return '❌';\n case 'info':\n default:\n return 'ℹ️';\n }\n});\n\n// Emit click event\nconst emit = defineEmits(['click']);\nconst handleClick = () => {\n emit('click', props.notification);\n};\n</script>\n\n<template>\n <div \n class=\"notification-item\" \n :class=\"{ unread: isUnread }\"\n @click=\"handleClick\"\n >\n <div class=\"notification-icon\">\n {{ notificationIcon }}\n </div>\n <div class=\"notification-content\">\n <h3 class=\"notification-title\">{{ notification.title }}</h3>\n <p class=\"notification-body\">{{ notification.body }}</p>\n <span class=\"notification-time\">{{ formattedDate }}</span>\n </div>\n <div v-if=\"isUnread\" class=\"unread-indicator\"></div>\n </div>\n</template>\n\n<style scoped>\n.notification-item {\n display: flex;\n padding: 1rem;\n border-radius: 8px;\n background-color: #fff;\n box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);\n cursor: pointer;\n transition: background-color 0.2s;\n}\n\n.notification-item:hover {\n background-color: #f9f9f9;\n}\n\n.notification-item.unread {\n background-color: #f0f7ff;\n}\n\n.notification-icon {\n flex-shrink: 0;\n margin-right: 1rem;\n font-size: 1.5rem;\n}\n\n.notification-content {\n flex: 1;\n}\n\n.notification-title {\n margin: 0 0 0.25rem;\n font-weight: 600;\n font-size: 1rem;\n}\n\n.notification-body {\n margin: 0 0 0.5rem;\n color: #666;\n font-size: 0.9rem;\n}\n\n.notification-time {\n font-size: 0.8rem;\n color: #999;\n}\n\n.unread-indicator {\n width: 10px;\n height: 10px;\n border-radius: 50%;\n background-color: var(--primary-color, #0066cc);\n align-self: center;\n margin-left: 0.5rem;\n}\n</style>"],"names":["computed"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AAIA,UAAM,QAAQ;AAQd,UAAM,WAAWA,IAAQ,SAAC,MAAM,MAAM,aAAa,WAAW,MAAM;AAGpE,UAAM,gBAAgBA,IAAQ,SAAC,MAAM;AACnC,YAAM,OAAO,IAAI,KAAK,MAAM,aAAa,SAAS;AAClD,YAAM,MAAM,oBAAI,KAAM;AACtB,YAAM,SAAS,MAAM;AACrB,YAAM,UAAU,KAAK,MAAM,SAAS,GAAI;AACxC,YAAM,UAAU,KAAK,MAAM,UAAU,EAAE;AACvC,YAAM,YAAY,KAAK,MAAM,UAAU,EAAE;AACzC,YAAM,WAAW,KAAK,MAAM,YAAY,EAAE;AAE1C,UAAI,UAAU,IAAI;AAChB,eAAO;AAAA,MACX,WAAa,UAAU,IAAI;AACvB,eAAO,GAAG,OAAO;AAAA,MACrB,WAAa,YAAY,IAAI;AACzB,eAAO,GAAG,SAAS;AAAA,MACvB,WAAa,WAAW,GAAG;AACvB,eAAO,GAAG,QAAQ;AAAA,MACtB,OAAS;AACL,eAAO,KAAK,mBAAoB;AAAA,MACpC;AAAA,IACA,CAAC;AAGD,UAAM,mBAAmBA,IAAQ,SAAC,MAAM;AACtC,cAAQ,MAAM,aAAa,MAAI;AAAA,QAC7B,KAAK;AACH,iBAAO;AAAA,QACT,KAAK;AACH,iBAAO;AAAA,QACT,KAAK;AACH,iBAAO;AAAA,QACT,KAAK;AAAA,QACL;AACE,iBAAO;AAAA,MACb;AAAA,IACA,CAAC;AAGD,UAAM,OAAO;AACb,UAAM,cAAc,MAAM;AACxB,WAAK,SAAS,MAAM,YAAY;AAAA,IAClC;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"NotificationItem.vue.cjs","sources":["../../../../../../../src/modules/notifications/components/blocks/NotificationItem.vue"],"sourcesContent":["<script setup>\nimport { computed } from 'vue';\n\n// Props\nconst props = defineProps({\n notification: {\n type: Object,\n required: true\n }\n});\n\n// Compute if notification is unread\nconst isUnread = computed(() => props.notification.status !== 'read');\n\n// Format date\nconst formattedDate = computed(() => {\n const date = new Date(props.notification.createdAt);\n const now = new Date();\n const diffMs = now - date;\n const diffSec = Math.floor(diffMs / 1000);\n const diffMin = Math.floor(diffSec / 60);\n const diffHours = Math.floor(diffMin / 60);\n const diffDays = Math.floor(diffHours / 24);\n \n if (diffSec < 60) {\n return 'Just now';\n } else if (diffMin < 60) {\n return `${diffMin}m ago`;\n } else if (diffHours < 24) {\n return `${diffHours}h ago`;\n } else if (diffDays < 7) {\n return `${diffDays}d ago`;\n } else {\n return date.toLocaleDateString();\n }\n});\n\n// Get icon based on notification type\nconst notificationIcon = computed(() => {\n switch (props.notification.type) {\n case 'alert':\n return '⚠️';\n case 'success':\n return '✅';\n case 'error':\n return '❌';\n case 'info':\n default:\n return 'ℹ️';\n }\n});\n\n// Emit click event\nconst emit = defineEmits(['click']);\nconst handleClick = () => {\n emit('click', props.notification);\n};\n</script>\n\n<template>\n <div \n class=\"notification-item gap-thin flex pd-small radius-small bg-light\" \n :class=\"{ 'bg-second-small': isUnread }\"\n @click=\"handleClick\"\n >\n <div class=\"notification-icon\">\n {{ notificationIcon }}\n </div>\n <div class=\"notification-content\">\n <p class=\"p-medium t-medium mn-b-small\">{{ notification.title }}</p>\n <p class=\"p-small mn-b-small\">{{ notification.body }}</p>\n <p class=\"pd-thin w-max radius-thin bg-white\">{{ formattedDate }}</p>\n </div>\n <div v-if=\"isUnread\" class=\"flex-child-default unread-indicator\"></div>\n </div>\n</template>\n\n<style scoped>\n.unread-indicator {\n width: 10px;\n height: 10px;\n border-radius: 50%;\n background-color: var(--primary-color, #0066cc);\n align-self: center;\n margin-left: 0.5rem;\n}\n</style>"],"names":["computed"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AAIA,UAAM,QAAQ;AAQd,UAAM,WAAWA,IAAQ,SAAC,MAAM,MAAM,aAAa,WAAW,MAAM;AAGpE,UAAM,gBAAgBA,IAAQ,SAAC,MAAM;AACnC,YAAM,OAAO,IAAI,KAAK,MAAM,aAAa,SAAS;AAClD,YAAM,MAAM,oBAAI,KAAM;AACtB,YAAM,SAAS,MAAM;AACrB,YAAM,UAAU,KAAK,MAAM,SAAS,GAAI;AACxC,YAAM,UAAU,KAAK,MAAM,UAAU,EAAE;AACvC,YAAM,YAAY,KAAK,MAAM,UAAU,EAAE;AACzC,YAAM,WAAW,KAAK,MAAM,YAAY,EAAE;AAE1C,UAAI,UAAU,IAAI;AAChB,eAAO;AAAA,MACX,WAAa,UAAU,IAAI;AACvB,eAAO,GAAG,OAAO;AAAA,MACrB,WAAa,YAAY,IAAI;AACzB,eAAO,GAAG,SAAS;AAAA,MACvB,WAAa,WAAW,GAAG;AACvB,eAAO,GAAG,QAAQ;AAAA,MACtB,OAAS;AACL,eAAO,KAAK,mBAAoB;AAAA,MACpC;AAAA,IACA,CAAC;AAGD,UAAM,mBAAmBA,IAAQ,SAAC,MAAM;AACtC,cAAQ,MAAM,aAAa,MAAI;AAAA,QAC7B,KAAK;AACH,iBAAO;AAAA,QACT,KAAK;AACH,iBAAO;AAAA,QACT,KAAK;AACH,iBAAO;AAAA,QACT,KAAK;AAAA,QACL;AACE,iBAAO;AAAA,MACb;AAAA,IACA,CAAC;AAGD,UAAM,OAAO;AACb,UAAM,cAAc,MAAM;AACxB,WAAK,SAAS,MAAM,YAAY;AAAA,IAClC;;;;;;;;;;;;;;;;;;;"}
@@ -2,12 +2,12 @@ import { computed, createElementBlock, openBlock, normalizeClass, createElementV
2
2
  import _export_sfc from "../../../../../../_virtual/_plugin-vue_export-helper.js";
3
3
  const _hoisted_1 = { class: "notification-icon" };
4
4
  const _hoisted_2 = { class: "notification-content" };
5
- const _hoisted_3 = { class: "notification-title" };
6
- const _hoisted_4 = { class: "notification-body" };
7
- const _hoisted_5 = { class: "notification-time" };
5
+ const _hoisted_3 = { class: "p-medium t-medium mn-b-small" };
6
+ const _hoisted_4 = { class: "p-small mn-b-small" };
7
+ const _hoisted_5 = { class: "pd-thin w-max radius-thin bg-white" };
8
8
  const _hoisted_6 = {
9
9
  key: 0,
10
- class: "unread-indicator"
10
+ class: "flex-child-default unread-indicator"
11
11
  };
12
12
  const _sfc_main = {
13
13
  __name: "NotificationItem",
@@ -60,21 +60,21 @@ const _sfc_main = {
60
60
  };
61
61
  return (_ctx, _cache) => {
62
62
  return openBlock(), createElementBlock("div", {
63
- class: normalizeClass(["notification-item", { unread: isUnread.value }]),
63
+ class: normalizeClass(["notification-item gap-thin flex pd-small radius-small bg-light", { "bg-second-small": isUnread.value }]),
64
64
  onClick: handleClick
65
65
  }, [
66
66
  createElementVNode("div", _hoisted_1, toDisplayString(notificationIcon.value), 1),
67
67
  createElementVNode("div", _hoisted_2, [
68
- createElementVNode("h3", _hoisted_3, toDisplayString(__props.notification.title), 1),
68
+ createElementVNode("p", _hoisted_3, toDisplayString(__props.notification.title), 1),
69
69
  createElementVNode("p", _hoisted_4, toDisplayString(__props.notification.body), 1),
70
- createElementVNode("span", _hoisted_5, toDisplayString(formattedDate.value), 1)
70
+ createElementVNode("p", _hoisted_5, toDisplayString(formattedDate.value), 1)
71
71
  ]),
72
72
  isUnread.value ? (openBlock(), createElementBlock("div", _hoisted_6)) : createCommentVNode("", true)
73
73
  ], 2);
74
74
  };
75
75
  }
76
76
  };
77
- const NotificationItem = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-c57c48a6"]]);
77
+ const NotificationItem = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-8aa96de9"]]);
78
78
  export {
79
79
  NotificationItem as default
80
80
  };
@@ -1 +1 @@
1
- {"version":3,"file":"NotificationItem.vue.js","sources":["../../../../../../../src/modules/notifications/components/blocks/NotificationItem.vue"],"sourcesContent":["<script setup>\nimport { computed } from 'vue';\n\n// Props\nconst props = defineProps({\n notification: {\n type: Object,\n required: true\n }\n});\n\n// Compute if notification is unread\nconst isUnread = computed(() => props.notification.status !== 'read');\n\n// Format date\nconst formattedDate = computed(() => {\n const date = new Date(props.notification.createdAt);\n const now = new Date();\n const diffMs = now - date;\n const diffSec = Math.floor(diffMs / 1000);\n const diffMin = Math.floor(diffSec / 60);\n const diffHours = Math.floor(diffMin / 60);\n const diffDays = Math.floor(diffHours / 24);\n \n if (diffSec < 60) {\n return 'Just now';\n } else if (diffMin < 60) {\n return `${diffMin}m ago`;\n } else if (diffHours < 24) {\n return `${diffHours}h ago`;\n } else if (diffDays < 7) {\n return `${diffDays}d ago`;\n } else {\n return date.toLocaleDateString();\n }\n});\n\n// Get icon based on notification type\nconst notificationIcon = computed(() => {\n switch (props.notification.type) {\n case 'alert':\n return '⚠️';\n case 'success':\n return '✅';\n case 'error':\n return '❌';\n case 'info':\n default:\n return 'ℹ️';\n }\n});\n\n// Emit click event\nconst emit = defineEmits(['click']);\nconst handleClick = () => {\n emit('click', props.notification);\n};\n</script>\n\n<template>\n <div \n class=\"notification-item\" \n :class=\"{ unread: isUnread }\"\n @click=\"handleClick\"\n >\n <div class=\"notification-icon\">\n {{ notificationIcon }}\n </div>\n <div class=\"notification-content\">\n <h3 class=\"notification-title\">{{ notification.title }}</h3>\n <p class=\"notification-body\">{{ notification.body }}</p>\n <span class=\"notification-time\">{{ formattedDate }}</span>\n </div>\n <div v-if=\"isUnread\" class=\"unread-indicator\"></div>\n </div>\n</template>\n\n<style scoped>\n.notification-item {\n display: flex;\n padding: 1rem;\n border-radius: 8px;\n background-color: #fff;\n box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);\n cursor: pointer;\n transition: background-color 0.2s;\n}\n\n.notification-item:hover {\n background-color: #f9f9f9;\n}\n\n.notification-item.unread {\n background-color: #f0f7ff;\n}\n\n.notification-icon {\n flex-shrink: 0;\n margin-right: 1rem;\n font-size: 1.5rem;\n}\n\n.notification-content {\n flex: 1;\n}\n\n.notification-title {\n margin: 0 0 0.25rem;\n font-weight: 600;\n font-size: 1rem;\n}\n\n.notification-body {\n margin: 0 0 0.5rem;\n color: #666;\n font-size: 0.9rem;\n}\n\n.notification-time {\n font-size: 0.8rem;\n color: #999;\n}\n\n.unread-indicator {\n width: 10px;\n height: 10px;\n border-radius: 50%;\n background-color: var(--primary-color, #0066cc);\n align-self: center;\n margin-left: 0.5rem;\n}\n</style>"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;AAIA,UAAM,QAAQ;AAQd,UAAM,WAAW,SAAS,MAAM,MAAM,aAAa,WAAW,MAAM;AAGpE,UAAM,gBAAgB,SAAS,MAAM;AACnC,YAAM,OAAO,IAAI,KAAK,MAAM,aAAa,SAAS;AAClD,YAAM,MAAM,oBAAI,KAAM;AACtB,YAAM,SAAS,MAAM;AACrB,YAAM,UAAU,KAAK,MAAM,SAAS,GAAI;AACxC,YAAM,UAAU,KAAK,MAAM,UAAU,EAAE;AACvC,YAAM,YAAY,KAAK,MAAM,UAAU,EAAE;AACzC,YAAM,WAAW,KAAK,MAAM,YAAY,EAAE;AAE1C,UAAI,UAAU,IAAI;AAChB,eAAO;AAAA,MACX,WAAa,UAAU,IAAI;AACvB,eAAO,GAAG,OAAO;AAAA,MACrB,WAAa,YAAY,IAAI;AACzB,eAAO,GAAG,SAAS;AAAA,MACvB,WAAa,WAAW,GAAG;AACvB,eAAO,GAAG,QAAQ;AAAA,MACtB,OAAS;AACL,eAAO,KAAK,mBAAoB;AAAA,MACpC;AAAA,IACA,CAAC;AAGD,UAAM,mBAAmB,SAAS,MAAM;AACtC,cAAQ,MAAM,aAAa,MAAI;AAAA,QAC7B,KAAK;AACH,iBAAO;AAAA,QACT,KAAK;AACH,iBAAO;AAAA,QACT,KAAK;AACH,iBAAO;AAAA,QACT,KAAK;AAAA,QACL;AACE,iBAAO;AAAA,MACb;AAAA,IACA,CAAC;AAGD,UAAM,OAAO;AACb,UAAM,cAAc,MAAM;AACxB,WAAK,SAAS,MAAM,YAAY;AAAA,IAClC;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"NotificationItem.vue.js","sources":["../../../../../../../src/modules/notifications/components/blocks/NotificationItem.vue"],"sourcesContent":["<script setup>\nimport { computed } from 'vue';\n\n// Props\nconst props = defineProps({\n notification: {\n type: Object,\n required: true\n }\n});\n\n// Compute if notification is unread\nconst isUnread = computed(() => props.notification.status !== 'read');\n\n// Format date\nconst formattedDate = computed(() => {\n const date = new Date(props.notification.createdAt);\n const now = new Date();\n const diffMs = now - date;\n const diffSec = Math.floor(diffMs / 1000);\n const diffMin = Math.floor(diffSec / 60);\n const diffHours = Math.floor(diffMin / 60);\n const diffDays = Math.floor(diffHours / 24);\n \n if (diffSec < 60) {\n return 'Just now';\n } else if (diffMin < 60) {\n return `${diffMin}m ago`;\n } else if (diffHours < 24) {\n return `${diffHours}h ago`;\n } else if (diffDays < 7) {\n return `${diffDays}d ago`;\n } else {\n return date.toLocaleDateString();\n }\n});\n\n// Get icon based on notification type\nconst notificationIcon = computed(() => {\n switch (props.notification.type) {\n case 'alert':\n return '⚠️';\n case 'success':\n return '✅';\n case 'error':\n return '❌';\n case 'info':\n default:\n return 'ℹ️';\n }\n});\n\n// Emit click event\nconst emit = defineEmits(['click']);\nconst handleClick = () => {\n emit('click', props.notification);\n};\n</script>\n\n<template>\n <div \n class=\"notification-item gap-thin flex pd-small radius-small bg-light\" \n :class=\"{ 'bg-second-small': isUnread }\"\n @click=\"handleClick\"\n >\n <div class=\"notification-icon\">\n {{ notificationIcon }}\n </div>\n <div class=\"notification-content\">\n <p class=\"p-medium t-medium mn-b-small\">{{ notification.title }}</p>\n <p class=\"p-small mn-b-small\">{{ notification.body }}</p>\n <p class=\"pd-thin w-max radius-thin bg-white\">{{ formattedDate }}</p>\n </div>\n <div v-if=\"isUnread\" class=\"flex-child-default unread-indicator\"></div>\n </div>\n</template>\n\n<style scoped>\n.unread-indicator {\n width: 10px;\n height: 10px;\n border-radius: 50%;\n background-color: var(--primary-color, #0066cc);\n align-self: center;\n margin-left: 0.5rem;\n}\n</style>"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;AAIA,UAAM,QAAQ;AAQd,UAAM,WAAW,SAAS,MAAM,MAAM,aAAa,WAAW,MAAM;AAGpE,UAAM,gBAAgB,SAAS,MAAM;AACnC,YAAM,OAAO,IAAI,KAAK,MAAM,aAAa,SAAS;AAClD,YAAM,MAAM,oBAAI,KAAM;AACtB,YAAM,SAAS,MAAM;AACrB,YAAM,UAAU,KAAK,MAAM,SAAS,GAAI;AACxC,YAAM,UAAU,KAAK,MAAM,UAAU,EAAE;AACvC,YAAM,YAAY,KAAK,MAAM,UAAU,EAAE;AACzC,YAAM,WAAW,KAAK,MAAM,YAAY,EAAE;AAE1C,UAAI,UAAU,IAAI;AAChB,eAAO;AAAA,MACX,WAAa,UAAU,IAAI;AACvB,eAAO,GAAG,OAAO;AAAA,MACrB,WAAa,YAAY,IAAI;AACzB,eAAO,GAAG,SAAS;AAAA,MACvB,WAAa,WAAW,GAAG;AACvB,eAAO,GAAG,QAAQ;AAAA,MACtB,OAAS;AACL,eAAO,KAAK,mBAAoB;AAAA,MACpC;AAAA,IACA,CAAC;AAGD,UAAM,mBAAmB,SAAS,MAAM;AACtC,cAAQ,MAAM,aAAa,MAAI;AAAA,QAC7B,KAAK;AACH,iBAAO;AAAA,QACT,KAAK;AACH,iBAAO;AAAA,QACT,KAAK;AACH,iBAAO;AAAA,QACT,KAAK;AAAA,QACL;AACE,iBAAO;AAAA,MACb;AAAA,IACA,CAAC;AAGD,UAAM,OAAO;AACb,UAAM,cAAc,MAAM;AACxB,WAAK,SAAS,MAAM,YAAY;AAAA,IAClC;;;;;;;;;;;;;;;;;;"}
@@ -2,6 +2,7 @@
2
2
  Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
3
3
  const vue = require("vue");
4
4
  const vueRouter = require("vue-router");
5
+ const Popup = require("../../../../components/Popup/Popup.vue2.cjs");
5
6
  const NotificationItem = require("../blocks/NotificationItem.vue.cjs");
6
7
  const auth = require("../../../auth/views/store/auth.cjs");
7
8
  const IconBell = require("../../../icons/entities/IconBell.vue.cjs");
@@ -12,30 +13,26 @@ const _hoisted_3 = {
12
13
  key: 0,
13
14
  class: "button-counter flex-center"
14
15
  };
15
- const _hoisted_4 = {
16
- key: 0,
17
- class: "notifications-dropdown"
18
- };
19
- const _hoisted_5 = { class: "notifications-header" };
20
- const _hoisted_6 = {
16
+ const _hoisted_4 = { class: "cols-1 gap-thin o-y-scroll" };
17
+ const _hoisted_5 = {
21
18
  key: 0,
22
19
  class: "notifications-loading"
23
20
  };
24
- const _hoisted_7 = {
21
+ const _hoisted_6 = {
25
22
  key: 1,
26
23
  class: "notifications-empty"
27
24
  };
28
- const _hoisted_8 = {
25
+ const _hoisted_7 = {
29
26
  key: 2,
30
- class: "notifications-list"
27
+ class: "flex-column flex gap-thin"
31
28
  };
32
- const _hoisted_9 = { class: "notifications-footer" };
29
+ const _hoisted_8 = { class: "flex-nowrap flex gap-thin" };
33
30
  const _sfc_main = {
34
31
  __name: "NotificationBadge",
35
32
  props: {
36
33
  maxNotifications: {
37
34
  type: Number,
38
- default: 5
35
+ default: 10
39
36
  },
40
37
  fill: {
41
38
  type: String,
@@ -53,6 +50,9 @@ const _sfc_main = {
53
50
  const toggleNotifications = () => {
54
51
  isOpen.value = !isOpen.value;
55
52
  };
53
+ const closeNotifications = () => {
54
+ isOpen.value = false;
55
+ };
56
56
  const handleNotificationClick = (notification) => {
57
57
  isOpen.value = false;
58
58
  if (notification._id) {
@@ -62,22 +62,12 @@ const _sfc_main = {
62
62
  });
63
63
  }
64
64
  };
65
- const handleClickOutside = (event) => {
66
- const container = document.querySelector(".notification-badge-container");
67
- if (container && !container.contains(event.target)) {
68
- isOpen.value = false;
69
- }
70
- };
71
65
  vue.onMounted(() => {
72
- document.addEventListener("click", handleClickOutside);
73
66
  const userId = auth.state.user._id;
74
67
  if (userId) {
75
68
  getNotifications(userId);
76
69
  }
77
70
  });
78
- vue.onUnmounted(() => {
79
- document.removeEventListener("click", handleClickOutside);
80
- });
81
71
  return (_ctx, _cache) => {
82
72
  const _component_router_link = vue.resolveComponent("router-link");
83
73
  return vue.openBlock(), vue.createElementBlock("div", _hoisted_1, [
@@ -94,40 +84,49 @@ const _sfc_main = {
94
84
  vue.createElementVNode("span", null, vue.toDisplayString(vue.unref(unreadCount) > 99 ? "99+" : vue.unref(unreadCount)), 1)
95
85
  ])) : vue.createCommentVNode("", true)
96
86
  ], 8, _hoisted_2),
97
- isOpen.value ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_4, [
98
- vue.createElementVNode("div", _hoisted_5, [
99
- _cache[2] || (_cache[2] = vue.createElementVNode("h3", null, "Notifications", -1)),
100
- vue.unref(unreadCount) > 0 ? (vue.openBlock(), vue.createElementBlock("button", {
101
- key: 0,
102
- class: "mark-all-read-btn",
103
- onClick: _cache[0] || (_cache[0] = (...args) => vue.unref(markAllAsRead) && vue.unref(markAllAsRead)(...args))
104
- }, " Mark all read ")) : vue.createCommentVNode("", true)
87
+ vue.createVNode(Popup.default, {
88
+ title: "Notifications",
89
+ onClosePopup: closeNotifications,
90
+ isPopupOpen: isOpen.value,
91
+ align: "center right",
92
+ class: "bg-white h-min-100 w-100 w-max-30r pd-medium"
93
+ }, {
94
+ default: vue.withCtx(() => [
95
+ vue.createElementVNode("div", _hoisted_4, [
96
+ vue.unref(loading) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_5, " Loading... ")) : vue.unref(notifications).length === 0 ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_6, " No notifications ")) : (vue.openBlock(), vue.createElementBlock("div", _hoisted_7, [
97
+ (vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(recentNotifications.value, (notification) => {
98
+ return vue.openBlock(), vue.createBlock(NotificationItem.default, {
99
+ key: notification._id,
100
+ notification,
101
+ onClick: ($event) => handleNotificationClick(notification)
102
+ }, null, 8, ["notification", "onClick"]);
103
+ }), 128)),
104
+ vue.createElementVNode("div", _hoisted_8, [
105
+ vue.unref(unreadCount) > 0 ? (vue.openBlock(), vue.createElementBlock("button", {
106
+ key: 0,
107
+ class: "w-100 bg-second t-white radius-small button",
108
+ onClick: _cache[0] || (_cache[0] = (...args) => vue.unref(markAllAsRead) && vue.unref(markAllAsRead)(...args))
109
+ }, " Mark all read ")) : vue.createCommentVNode("", true),
110
+ vue.createVNode(_component_router_link, {
111
+ class: "w-100 bg-black t-white radius-small button",
112
+ to: "/notifications",
113
+ onClick: closeNotifications
114
+ }, {
115
+ default: vue.withCtx(() => _cache[1] || (_cache[1] = [
116
+ vue.createTextVNode(" View all ")
117
+ ])),
118
+ _: 1
119
+ })
120
+ ])
121
+ ]))
122
+ ])
105
123
  ]),
106
- vue.unref(loading) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_6, " Loading... ")) : vue.unref(notifications).length === 0 ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_7, " No notifications ")) : (vue.openBlock(), vue.createElementBlock("div", _hoisted_8, [
107
- (vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(recentNotifications.value, (notification) => {
108
- return vue.openBlock(), vue.createBlock(NotificationItem.default, {
109
- key: notification._id,
110
- notification,
111
- onClick: ($event) => handleNotificationClick(notification)
112
- }, null, 8, ["notification", "onClick"]);
113
- }), 128))
114
- ])),
115
- vue.createElementVNode("div", _hoisted_9, [
116
- vue.createVNode(_component_router_link, {
117
- to: "/notifications",
118
- onClick: _cache[1] || (_cache[1] = ($event) => isOpen.value = false)
119
- }, {
120
- default: vue.withCtx(() => _cache[3] || (_cache[3] = [
121
- vue.createTextVNode(" View all notifications ")
122
- ])),
123
- _: 1
124
- })
125
- ])
126
- ])) : vue.createCommentVNode("", true)
124
+ _: 1
125
+ }, 8, ["isPopupOpen"])
127
126
  ]);
128
127
  };
129
128
  }
130
129
  };
131
- const NotificationBadge = /* @__PURE__ */ _pluginVue_exportHelper.default(_sfc_main, [["__scopeId", "data-v-a7d7de5f"]]);
130
+ const NotificationBadge = /* @__PURE__ */ _pluginVue_exportHelper.default(_sfc_main, [["__scopeId", "data-v-26b93994"]]);
132
131
  exports.default = NotificationBadge;
133
132
  //# sourceMappingURL=NotificationBadge.vue.cjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"NotificationBadge.vue.cjs","sources":["../../../../../../../src/modules/notifications/components/elements/NotificationBadge.vue"],"sourcesContent":["<template>\n <div class=\"notification-badge-container\">\n <button \n class=\"i-semi notification-button\"\n @click=\"toggleNotifications\"\n :aria-label=\"unreadCount > 0 ? `${unreadCount} unread notifications` : 'No unread notifications'\"\n >\n <IconBell class=\"notification-icon i-medium\" :fill=\"fill\"/>\n <div \n v-if=\"unreadCount > 0\" \n class=\"button-counter flex-center\"\n >\n <span>{{ unreadCount > 99 ? '99+' : unreadCount }}</span>\n </div>\n </button>\n <div v-if=\"isOpen\" class=\"notifications-dropdown\">\n <div class=\"notifications-header\">\n <h3>Notifications</h3>\n <button \n v-if=\"unreadCount > 0\" \n class=\"mark-all-read-btn\" \n @click=\"markAllAsRead\"\n >\n Mark all read\n </button>\n </div>\n <div v-if=\"loading\" class=\"notifications-loading\">\n Loading...\n </div>\n <div v-else-if=\"notifications.length === 0\" class=\"notifications-empty\">\n No notifications\n </div>\n <div v-else class=\"notifications-list\">\n <notification-item \n v-for=\"notification in recentNotifications\" \n :key=\"notification._id\" \n :notification=\"notification\"\n @click=\"handleNotificationClick(notification)\"\n />\n </div>\n <div class=\"notifications-footer\">\n <router-link to=\"/notifications\" @click=\"isOpen = false\">\n View all notifications\n </router-link>\n </div>\n </div>\n </div>\n</template>\n\n<script setup>\nimport { ref, computed, onMounted, onUnmounted, inject } from 'vue';\nimport { useRouter } from 'vue-router';\nimport NotificationItem from '../blocks/NotificationItem.vue';\nimport * as auth from '@martyrs/src/modules/auth/views/store/auth.js';\n\nimport IconBell from '@martyrs/src/modules/icons/entities/IconBell.vue';\n\nconst props = defineProps({\n maxNotifications: {\n type: Number,\n default: 5\n },\n fill: {\n type: String,\n default: 'rgb(var(--white))'\n }\n});\n\n// Get router and notification functionality\nconst router = useRouter();\nconst { notifications, unreadCount, loading, markAllAsRead, getNotifications } = inject('useNotifications')();\n\n// Local state\nconst isOpen = ref(false);\n\n// Computed properties\nconst recentNotifications = computed(() => {\n return notifications.value\n .slice()\n .sort((a, b) => new Date(b.createdAt) - new Date(a.createdAt))\n .slice(0, props.maxNotifications);\n});\n\n// Methods\nconst toggleNotifications = () => {\n isOpen.value = !isOpen.value;\n};\n\nconst handleNotificationClick = (notification) => {\n isOpen.value = false;\n \n if (notification._id) {\n // Handle in store\n actions.handleNotificationAction({\n notificationId: notification._id,\n ...notification.metadata\n });\n }\n};\n\n// Close dropdown when clicking outside\nconst handleClickOutside = (event) => {\n const container = document.querySelector('.notification-badge-container');\n if (container && !container.contains(event.target)) {\n isOpen.value = false;\n }\n};\n\n// Lifecycle hooks\nonMounted(() => {\n document.addEventListener('click', handleClickOutside);\n\n // Load notifications when component mounts\n const userId = auth.state.user._id;\n if (userId) {\n getNotifications(userId);\n }\n});\n\nonUnmounted(() => {\n document.removeEventListener('click', handleClickOutside);\n});\n</script>\n\n<style scoped>\n.notification-badge-container {\n position: relative;\n display: inline-block;\n}\n\n.notification-button {\n background: none;\n border: none;\n cursor: pointer;\n position: relative;\n font-size: 1.2rem;\n}\n\n.notification-icon {\n font-size: 1.4rem;\n}\n.button-counter {\n position: absolute;\n right: -8px;\n bottom: -8px;\n background: rgb(var(--fourth));\n color: rgb(var(--white));\n height: 16px;\n border-radius: 16px;\n width: 16px;\n font-weight: 500;\n text-align: center;\n line-height: 16px;\n font-size: 10px;\n}\n.notifications-dropdown {\n position: absolute;\n top: 100%;\n right: 0;\n width: 320px;\n max-height: 400px;\n overflow-y: auto;\n background-color: white;\n border-radius: 4px;\n box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);\n z-index: 1000;\n}\n\n.notifications-header {\n display: flex;\n justify-content: space-between;\n align-items: center;\n padding: 12px 16px;\n border-bottom: 1px solid #eee;\n}\n\n.notifications-header h3 {\n margin: 0;\n font-size: 1rem;\n}\n\n.mark-all-read-btn {\n background: none;\n border: none;\n color: #2196f3;\n font-size: 0.8rem;\n cursor: pointer;\n}\n\n.notifications-loading,\n.notifications-empty {\n padding: 24px;\n text-align: center;\n color: #666;\n}\n\n.notifications-list {\n max-height: 300px;\n overflow-y: auto;\n}\n\n.notifications-footer {\n padding: 12px 16px;\n text-align: center;\n border-top: 1px solid #eee;\n}\n\n.notifications-footer a {\n color: #2196f3;\n text-decoration: none;\n font-size: 0.9rem;\n}\n</style>"],"names":["useRouter","inject","ref","computed","onMounted","auth.state","onUnmounted"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAyDA,UAAM,QAAQ;AAYCA,cAAS,UAAA;AACxB,UAAM,EAAE,eAAe,aAAa,SAAS,eAAe,qBAAqBC,IAAAA,OAAO,kBAAkB,EAAG;AAG7G,UAAM,SAASC,IAAG,IAAC,KAAK;AAGxB,UAAM,sBAAsBC,IAAQ,SAAC,MAAM;AACzC,aAAO,cAAc,MAClB,MAAK,EACL,KAAK,CAAC,GAAG,MAAM,IAAI,KAAK,EAAE,SAAS,IAAI,IAAI,KAAK,EAAE,SAAS,CAAC,EAC5D,MAAM,GAAG,MAAM,gBAAgB;AAAA,IACpC,CAAC;AAGD,UAAM,sBAAsB,MAAM;AAChC,aAAO,QAAQ,CAAC,OAAO;AAAA,IACzB;AAEA,UAAM,0BAA0B,CAAC,iBAAiB;AAChD,aAAO,QAAQ;AAEf,UAAI,aAAa,KAAK;AAEpB,gBAAQ,yBAAyB;AAAA,UAC/B,gBAAgB,aAAa;AAAA,UAC7B,GAAG,aAAa;AAAA,QACtB,CAAK;AAAA,MACL;AAAA,IACA;AAGA,UAAM,qBAAqB,CAAC,UAAU;AACpC,YAAM,YAAY,SAAS,cAAc,+BAA+B;AACxE,UAAI,aAAa,CAAC,UAAU,SAAS,MAAM,MAAM,GAAG;AAClD,eAAO,QAAQ;AAAA,MACnB;AAAA,IACA;AAGAC,QAAAA,UAAU,MAAM;AACd,eAAS,iBAAiB,SAAS,kBAAkB;AAGrD,YAAM,SAASC,WAAW,KAAK;AAC/B,UAAI,QAAQ;AACV,yBAAiB,MAAM;AAAA,MAC3B;AAAA,IACA,CAAC;AAEDC,QAAAA,YAAY,MAAM;AAChB,eAAS,oBAAoB,SAAS,kBAAkB;AAAA,IAC1D,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"NotificationBadge.vue.cjs","sources":["../../../../../../../src/modules/notifications/components/elements/NotificationBadge.vue"],"sourcesContent":["<template>\n <div class=\"notification-badge-container\">\n <button \n class=\"i-semi notification-button\"\n @click=\"toggleNotifications\"\n :aria-label=\"unreadCount > 0 ? `${unreadCount} unread notifications` : 'No unread notifications'\"\n >\n <IconBell class=\"notification-icon i-medium\" :fill=\"fill\"/>\n <div \n v-if=\"unreadCount > 0\" \n class=\"button-counter flex-center\"\n >\n <span>{{ unreadCount > 99 ? '99+' : unreadCount }}</span>\n </div>\n </button>\n \n <Popup\n title=\"Notifications\"\n @close-popup=\"closeNotifications\"\n :isPopupOpen=\"isOpen\"\n align=\"center right\"\n class=\"bg-white h-min-100 w-100 w-max-30r pd-medium\"\n >\n <div class=\"cols-1 gap-thin o-y-scroll\">\n <div v-if=\"loading\" class=\"notifications-loading\">\n Loading...\n </div>\n \n <div v-else-if=\"notifications.length === 0\" class=\"notifications-empty\">\n No notifications\n </div>\n \n <div v-else class=\"flex-column flex gap-thin\">\n <notification-item \n v-for=\"notification in recentNotifications\" \n :key=\"notification._id\" \n :notification=\"notification\"\n @click=\"handleNotificationClick(notification)\"\n />\n\n <div class=\"flex-nowrap flex gap-thin\">\n <button \n v-if=\"unreadCount > 0\"\n class=\"w-100 bg-second t-white radius-small button\" \n @click=\"markAllAsRead\"\n >\n Mark all read\n </button>\n\n <router-link class=\"w-100 bg-black t-white radius-small button\" to=\"/notifications\" @click=\"closeNotifications\">\n View all \n </router-link>\n </div>\n\n </div>\n\n </div>\n </Popup>\n </div>\n</template>\n\n<script setup>\nimport { ref, computed, onMounted, inject } from 'vue';\nimport { useRouter } from 'vue-router';\n\nimport Popup from '@martyrs/src/components/Popup/Popup.vue';\n\nimport NotificationItem from '../blocks/NotificationItem.vue';\nimport * as auth from '@martyrs/src/modules/auth/views/store/auth.js';\nimport IconBell from '@martyrs/src/modules/icons/entities/IconBell.vue';\n\nconst props = defineProps({\n maxNotifications: {\n type: Number,\n default: 10\n },\n fill: {\n type: String,\n default: 'rgb(var(--white))'\n }\n});\n\n// Get router and notification functionality\nconst router = useRouter();\nconst { notifications, unreadCount, loading, markAllAsRead, getNotifications } = inject('useNotifications')();\n\n// Local state\nconst isOpen = ref(false);\n\n// Computed properties\nconst recentNotifications = computed(() => {\n return notifications.value\n .slice()\n .sort((a, b) => new Date(b.createdAt) - new Date(a.createdAt))\n .slice(0, props.maxNotifications);\n});\n\n// Methods\nconst toggleNotifications = () => {\n isOpen.value = !isOpen.value;\n};\n\nconst closeNotifications = () => {\n isOpen.value = false;\n};\n\nconst handleNotificationClick = (notification) => {\n isOpen.value = false;\n \n if (notification._id) {\n // Handle in store\n actions.handleNotificationAction({\n notificationId: notification._id,\n ...notification.metadata\n });\n }\n};\n\n// Lifecycle hooks\nonMounted(() => {\n // Load notifications when component mounts\n const userId = auth.state.user._id;\n if (userId) {\n getNotifications(userId);\n }\n});\n</script>\n\n<style scoped>\n.notification-badge-container {\n position: relative;\n display: inline-block;\n}\n\n.notification-button {\n background: none;\n border: none;\n cursor: pointer;\n position: relative;\n font-size: 1.2rem;\n}\n\n.notification-icon {\n font-size: 1.4rem;\n}\n\n.button-counter {\n position: absolute;\n right: -8px;\n bottom: -8px;\n background: rgb(var(--fourth));\n color: rgb(var(--white));\n height: 16px;\n border-radius: 16px;\n width: 16px;\n font-weight: 500;\n text-align: center;\n line-height: 16px;\n font-size: 10px;\n}\n\n\n.notifications-loading,\n.notifications-empty {\n padding: 24px;\n text-align: center;\n color: rgb(var(--text-light));\n}\n</style>"],"names":["useRouter","inject","ref","computed","onMounted","auth.state"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAuEA,UAAM,QAAQ;AAYCA,cAAS,UAAA;AACxB,UAAM,EAAE,eAAe,aAAa,SAAS,eAAe,qBAAqBC,IAAAA,OAAO,kBAAkB,EAAG;AAG7G,UAAM,SAASC,IAAG,IAAC,KAAK;AAGxB,UAAM,sBAAsBC,IAAQ,SAAC,MAAM;AACzC,aAAO,cAAc,MAClB,MAAK,EACL,KAAK,CAAC,GAAG,MAAM,IAAI,KAAK,EAAE,SAAS,IAAI,IAAI,KAAK,EAAE,SAAS,CAAC,EAC5D,MAAM,GAAG,MAAM,gBAAgB;AAAA,IACpC,CAAC;AAGD,UAAM,sBAAsB,MAAM;AAChC,aAAO,QAAQ,CAAC,OAAO;AAAA,IACzB;AAEA,UAAM,qBAAqB,MAAM;AAC/B,aAAO,QAAQ;AAAA,IACjB;AAEA,UAAM,0BAA0B,CAAC,iBAAiB;AAChD,aAAO,QAAQ;AAEf,UAAI,aAAa,KAAK;AAEpB,gBAAQ,yBAAyB;AAAA,UAC/B,gBAAgB,aAAa;AAAA,UAC7B,GAAG,aAAa;AAAA,QACtB,CAAK;AAAA,MACL;AAAA,IACA;AAGAC,QAAAA,UAAU,MAAM;AAEd,YAAM,SAASC,WAAW,KAAK;AAC/B,UAAI,QAAQ;AACV,yBAAiB,MAAM;AAAA,MAC3B;AAAA,IACA,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -1,5 +1,6 @@
1
- import { inject, ref, computed, onMounted, onUnmounted, resolveComponent, createElementBlock, openBlock, createElementVNode, createCommentVNode, unref, createVNode, toDisplayString, Fragment, renderList, createBlock, withCtx, createTextVNode } from "vue";
1
+ import { inject, ref, computed, onMounted, resolveComponent, createElementBlock, openBlock, createElementVNode, createVNode, unref, createCommentVNode, toDisplayString, withCtx, Fragment, renderList, createBlock, createTextVNode } from "vue";
2
2
  import { useRouter } from "vue-router";
3
+ import _sfc_main$2 from "../../../../components/Popup/Popup.vue2.js";
3
4
  import NotificationItem from "../blocks/NotificationItem.vue.js";
4
5
  import { state } from "../../../auth/views/store/auth.js";
5
6
  import _sfc_main$1 from "../../../icons/entities/IconBell.vue.js";
@@ -10,30 +11,26 @@ const _hoisted_3 = {
10
11
  key: 0,
11
12
  class: "button-counter flex-center"
12
13
  };
13
- const _hoisted_4 = {
14
- key: 0,
15
- class: "notifications-dropdown"
16
- };
17
- const _hoisted_5 = { class: "notifications-header" };
18
- const _hoisted_6 = {
14
+ const _hoisted_4 = { class: "cols-1 gap-thin o-y-scroll" };
15
+ const _hoisted_5 = {
19
16
  key: 0,
20
17
  class: "notifications-loading"
21
18
  };
22
- const _hoisted_7 = {
19
+ const _hoisted_6 = {
23
20
  key: 1,
24
21
  class: "notifications-empty"
25
22
  };
26
- const _hoisted_8 = {
23
+ const _hoisted_7 = {
27
24
  key: 2,
28
- class: "notifications-list"
25
+ class: "flex-column flex gap-thin"
29
26
  };
30
- const _hoisted_9 = { class: "notifications-footer" };
27
+ const _hoisted_8 = { class: "flex-nowrap flex gap-thin" };
31
28
  const _sfc_main = {
32
29
  __name: "NotificationBadge",
33
30
  props: {
34
31
  maxNotifications: {
35
32
  type: Number,
36
- default: 5
33
+ default: 10
37
34
  },
38
35
  fill: {
39
36
  type: String,
@@ -51,6 +48,9 @@ const _sfc_main = {
51
48
  const toggleNotifications = () => {
52
49
  isOpen.value = !isOpen.value;
53
50
  };
51
+ const closeNotifications = () => {
52
+ isOpen.value = false;
53
+ };
54
54
  const handleNotificationClick = (notification) => {
55
55
  isOpen.value = false;
56
56
  if (notification._id) {
@@ -60,22 +60,12 @@ const _sfc_main = {
60
60
  });
61
61
  }
62
62
  };
63
- const handleClickOutside = (event) => {
64
- const container = document.querySelector(".notification-badge-container");
65
- if (container && !container.contains(event.target)) {
66
- isOpen.value = false;
67
- }
68
- };
69
63
  onMounted(() => {
70
- document.addEventListener("click", handleClickOutside);
71
64
  const userId = state.user._id;
72
65
  if (userId) {
73
66
  getNotifications(userId);
74
67
  }
75
68
  });
76
- onUnmounted(() => {
77
- document.removeEventListener("click", handleClickOutside);
78
- });
79
69
  return (_ctx, _cache) => {
80
70
  const _component_router_link = resolveComponent("router-link");
81
71
  return openBlock(), createElementBlock("div", _hoisted_1, [
@@ -92,41 +82,50 @@ const _sfc_main = {
92
82
  createElementVNode("span", null, toDisplayString(unref(unreadCount) > 99 ? "99+" : unref(unreadCount)), 1)
93
83
  ])) : createCommentVNode("", true)
94
84
  ], 8, _hoisted_2),
95
- isOpen.value ? (openBlock(), createElementBlock("div", _hoisted_4, [
96
- createElementVNode("div", _hoisted_5, [
97
- _cache[2] || (_cache[2] = createElementVNode("h3", null, "Notifications", -1)),
98
- unref(unreadCount) > 0 ? (openBlock(), createElementBlock("button", {
99
- key: 0,
100
- class: "mark-all-read-btn",
101
- onClick: _cache[0] || (_cache[0] = (...args) => unref(markAllAsRead) && unref(markAllAsRead)(...args))
102
- }, " Mark all read ")) : createCommentVNode("", true)
85
+ createVNode(_sfc_main$2, {
86
+ title: "Notifications",
87
+ onClosePopup: closeNotifications,
88
+ isPopupOpen: isOpen.value,
89
+ align: "center right",
90
+ class: "bg-white h-min-100 w-100 w-max-30r pd-medium"
91
+ }, {
92
+ default: withCtx(() => [
93
+ createElementVNode("div", _hoisted_4, [
94
+ unref(loading) ? (openBlock(), createElementBlock("div", _hoisted_5, " Loading... ")) : unref(notifications).length === 0 ? (openBlock(), createElementBlock("div", _hoisted_6, " No notifications ")) : (openBlock(), createElementBlock("div", _hoisted_7, [
95
+ (openBlock(true), createElementBlock(Fragment, null, renderList(recentNotifications.value, (notification) => {
96
+ return openBlock(), createBlock(NotificationItem, {
97
+ key: notification._id,
98
+ notification,
99
+ onClick: ($event) => handleNotificationClick(notification)
100
+ }, null, 8, ["notification", "onClick"]);
101
+ }), 128)),
102
+ createElementVNode("div", _hoisted_8, [
103
+ unref(unreadCount) > 0 ? (openBlock(), createElementBlock("button", {
104
+ key: 0,
105
+ class: "w-100 bg-second t-white radius-small button",
106
+ onClick: _cache[0] || (_cache[0] = (...args) => unref(markAllAsRead) && unref(markAllAsRead)(...args))
107
+ }, " Mark all read ")) : createCommentVNode("", true),
108
+ createVNode(_component_router_link, {
109
+ class: "w-100 bg-black t-white radius-small button",
110
+ to: "/notifications",
111
+ onClick: closeNotifications
112
+ }, {
113
+ default: withCtx(() => _cache[1] || (_cache[1] = [
114
+ createTextVNode(" View all ")
115
+ ])),
116
+ _: 1
117
+ })
118
+ ])
119
+ ]))
120
+ ])
103
121
  ]),
104
- unref(loading) ? (openBlock(), createElementBlock("div", _hoisted_6, " Loading... ")) : unref(notifications).length === 0 ? (openBlock(), createElementBlock("div", _hoisted_7, " No notifications ")) : (openBlock(), createElementBlock("div", _hoisted_8, [
105
- (openBlock(true), createElementBlock(Fragment, null, renderList(recentNotifications.value, (notification) => {
106
- return openBlock(), createBlock(NotificationItem, {
107
- key: notification._id,
108
- notification,
109
- onClick: ($event) => handleNotificationClick(notification)
110
- }, null, 8, ["notification", "onClick"]);
111
- }), 128))
112
- ])),
113
- createElementVNode("div", _hoisted_9, [
114
- createVNode(_component_router_link, {
115
- to: "/notifications",
116
- onClick: _cache[1] || (_cache[1] = ($event) => isOpen.value = false)
117
- }, {
118
- default: withCtx(() => _cache[3] || (_cache[3] = [
119
- createTextVNode(" View all notifications ")
120
- ])),
121
- _: 1
122
- })
123
- ])
124
- ])) : createCommentVNode("", true)
122
+ _: 1
123
+ }, 8, ["isPopupOpen"])
125
124
  ]);
126
125
  };
127
126
  }
128
127
  };
129
- const NotificationBadge = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-a7d7de5f"]]);
128
+ const NotificationBadge = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-26b93994"]]);
130
129
  export {
131
130
  NotificationBadge as default
132
131
  };
@@ -1 +1 @@
1
- {"version":3,"file":"NotificationBadge.vue.js","sources":["../../../../../../../src/modules/notifications/components/elements/NotificationBadge.vue"],"sourcesContent":["<template>\n <div class=\"notification-badge-container\">\n <button \n class=\"i-semi notification-button\"\n @click=\"toggleNotifications\"\n :aria-label=\"unreadCount > 0 ? `${unreadCount} unread notifications` : 'No unread notifications'\"\n >\n <IconBell class=\"notification-icon i-medium\" :fill=\"fill\"/>\n <div \n v-if=\"unreadCount > 0\" \n class=\"button-counter flex-center\"\n >\n <span>{{ unreadCount > 99 ? '99+' : unreadCount }}</span>\n </div>\n </button>\n <div v-if=\"isOpen\" class=\"notifications-dropdown\">\n <div class=\"notifications-header\">\n <h3>Notifications</h3>\n <button \n v-if=\"unreadCount > 0\" \n class=\"mark-all-read-btn\" \n @click=\"markAllAsRead\"\n >\n Mark all read\n </button>\n </div>\n <div v-if=\"loading\" class=\"notifications-loading\">\n Loading...\n </div>\n <div v-else-if=\"notifications.length === 0\" class=\"notifications-empty\">\n No notifications\n </div>\n <div v-else class=\"notifications-list\">\n <notification-item \n v-for=\"notification in recentNotifications\" \n :key=\"notification._id\" \n :notification=\"notification\"\n @click=\"handleNotificationClick(notification)\"\n />\n </div>\n <div class=\"notifications-footer\">\n <router-link to=\"/notifications\" @click=\"isOpen = false\">\n View all notifications\n </router-link>\n </div>\n </div>\n </div>\n</template>\n\n<script setup>\nimport { ref, computed, onMounted, onUnmounted, inject } from 'vue';\nimport { useRouter } from 'vue-router';\nimport NotificationItem from '../blocks/NotificationItem.vue';\nimport * as auth from '@martyrs/src/modules/auth/views/store/auth.js';\n\nimport IconBell from '@martyrs/src/modules/icons/entities/IconBell.vue';\n\nconst props = defineProps({\n maxNotifications: {\n type: Number,\n default: 5\n },\n fill: {\n type: String,\n default: 'rgb(var(--white))'\n }\n});\n\n// Get router and notification functionality\nconst router = useRouter();\nconst { notifications, unreadCount, loading, markAllAsRead, getNotifications } = inject('useNotifications')();\n\n// Local state\nconst isOpen = ref(false);\n\n// Computed properties\nconst recentNotifications = computed(() => {\n return notifications.value\n .slice()\n .sort((a, b) => new Date(b.createdAt) - new Date(a.createdAt))\n .slice(0, props.maxNotifications);\n});\n\n// Methods\nconst toggleNotifications = () => {\n isOpen.value = !isOpen.value;\n};\n\nconst handleNotificationClick = (notification) => {\n isOpen.value = false;\n \n if (notification._id) {\n // Handle in store\n actions.handleNotificationAction({\n notificationId: notification._id,\n ...notification.metadata\n });\n }\n};\n\n// Close dropdown when clicking outside\nconst handleClickOutside = (event) => {\n const container = document.querySelector('.notification-badge-container');\n if (container && !container.contains(event.target)) {\n isOpen.value = false;\n }\n};\n\n// Lifecycle hooks\nonMounted(() => {\n document.addEventListener('click', handleClickOutside);\n\n // Load notifications when component mounts\n const userId = auth.state.user._id;\n if (userId) {\n getNotifications(userId);\n }\n});\n\nonUnmounted(() => {\n document.removeEventListener('click', handleClickOutside);\n});\n</script>\n\n<style scoped>\n.notification-badge-container {\n position: relative;\n display: inline-block;\n}\n\n.notification-button {\n background: none;\n border: none;\n cursor: pointer;\n position: relative;\n font-size: 1.2rem;\n}\n\n.notification-icon {\n font-size: 1.4rem;\n}\n.button-counter {\n position: absolute;\n right: -8px;\n bottom: -8px;\n background: rgb(var(--fourth));\n color: rgb(var(--white));\n height: 16px;\n border-radius: 16px;\n width: 16px;\n font-weight: 500;\n text-align: center;\n line-height: 16px;\n font-size: 10px;\n}\n.notifications-dropdown {\n position: absolute;\n top: 100%;\n right: 0;\n width: 320px;\n max-height: 400px;\n overflow-y: auto;\n background-color: white;\n border-radius: 4px;\n box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);\n z-index: 1000;\n}\n\n.notifications-header {\n display: flex;\n justify-content: space-between;\n align-items: center;\n padding: 12px 16px;\n border-bottom: 1px solid #eee;\n}\n\n.notifications-header h3 {\n margin: 0;\n font-size: 1rem;\n}\n\n.mark-all-read-btn {\n background: none;\n border: none;\n color: #2196f3;\n font-size: 0.8rem;\n cursor: pointer;\n}\n\n.notifications-loading,\n.notifications-empty {\n padding: 24px;\n text-align: center;\n color: #666;\n}\n\n.notifications-list {\n max-height: 300px;\n overflow-y: auto;\n}\n\n.notifications-footer {\n padding: 12px 16px;\n text-align: center;\n border-top: 1px solid #eee;\n}\n\n.notifications-footer a {\n color: #2196f3;\n text-decoration: none;\n font-size: 0.9rem;\n}\n</style>"],"names":["auth.state"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAyDA,UAAM,QAAQ;AAYC,cAAS;AACxB,UAAM,EAAE,eAAe,aAAa,SAAS,eAAe,qBAAqB,OAAO,kBAAkB,EAAG;AAG7G,UAAM,SAAS,IAAI,KAAK;AAGxB,UAAM,sBAAsB,SAAS,MAAM;AACzC,aAAO,cAAc,MAClB,MAAK,EACL,KAAK,CAAC,GAAG,MAAM,IAAI,KAAK,EAAE,SAAS,IAAI,IAAI,KAAK,EAAE,SAAS,CAAC,EAC5D,MAAM,GAAG,MAAM,gBAAgB;AAAA,IACpC,CAAC;AAGD,UAAM,sBAAsB,MAAM;AAChC,aAAO,QAAQ,CAAC,OAAO;AAAA,IACzB;AAEA,UAAM,0BAA0B,CAAC,iBAAiB;AAChD,aAAO,QAAQ;AAEf,UAAI,aAAa,KAAK;AAEpB,gBAAQ,yBAAyB;AAAA,UAC/B,gBAAgB,aAAa;AAAA,UAC7B,GAAG,aAAa;AAAA,QACtB,CAAK;AAAA,MACL;AAAA,IACA;AAGA,UAAM,qBAAqB,CAAC,UAAU;AACpC,YAAM,YAAY,SAAS,cAAc,+BAA+B;AACxE,UAAI,aAAa,CAAC,UAAU,SAAS,MAAM,MAAM,GAAG;AAClD,eAAO,QAAQ;AAAA,MACnB;AAAA,IACA;AAGA,cAAU,MAAM;AACd,eAAS,iBAAiB,SAAS,kBAAkB;AAGrD,YAAM,SAASA,MAAW,KAAK;AAC/B,UAAI,QAAQ;AACV,yBAAiB,MAAM;AAAA,MAC3B;AAAA,IACA,CAAC;AAED,gBAAY,MAAM;AAChB,eAAS,oBAAoB,SAAS,kBAAkB;AAAA,IAC1D,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"NotificationBadge.vue.js","sources":["../../../../../../../src/modules/notifications/components/elements/NotificationBadge.vue"],"sourcesContent":["<template>\n <div class=\"notification-badge-container\">\n <button \n class=\"i-semi notification-button\"\n @click=\"toggleNotifications\"\n :aria-label=\"unreadCount > 0 ? `${unreadCount} unread notifications` : 'No unread notifications'\"\n >\n <IconBell class=\"notification-icon i-medium\" :fill=\"fill\"/>\n <div \n v-if=\"unreadCount > 0\" \n class=\"button-counter flex-center\"\n >\n <span>{{ unreadCount > 99 ? '99+' : unreadCount }}</span>\n </div>\n </button>\n \n <Popup\n title=\"Notifications\"\n @close-popup=\"closeNotifications\"\n :isPopupOpen=\"isOpen\"\n align=\"center right\"\n class=\"bg-white h-min-100 w-100 w-max-30r pd-medium\"\n >\n <div class=\"cols-1 gap-thin o-y-scroll\">\n <div v-if=\"loading\" class=\"notifications-loading\">\n Loading...\n </div>\n \n <div v-else-if=\"notifications.length === 0\" class=\"notifications-empty\">\n No notifications\n </div>\n \n <div v-else class=\"flex-column flex gap-thin\">\n <notification-item \n v-for=\"notification in recentNotifications\" \n :key=\"notification._id\" \n :notification=\"notification\"\n @click=\"handleNotificationClick(notification)\"\n />\n\n <div class=\"flex-nowrap flex gap-thin\">\n <button \n v-if=\"unreadCount > 0\"\n class=\"w-100 bg-second t-white radius-small button\" \n @click=\"markAllAsRead\"\n >\n Mark all read\n </button>\n\n <router-link class=\"w-100 bg-black t-white radius-small button\" to=\"/notifications\" @click=\"closeNotifications\">\n View all \n </router-link>\n </div>\n\n </div>\n\n </div>\n </Popup>\n </div>\n</template>\n\n<script setup>\nimport { ref, computed, onMounted, inject } from 'vue';\nimport { useRouter } from 'vue-router';\n\nimport Popup from '@martyrs/src/components/Popup/Popup.vue';\n\nimport NotificationItem from '../blocks/NotificationItem.vue';\nimport * as auth from '@martyrs/src/modules/auth/views/store/auth.js';\nimport IconBell from '@martyrs/src/modules/icons/entities/IconBell.vue';\n\nconst props = defineProps({\n maxNotifications: {\n type: Number,\n default: 10\n },\n fill: {\n type: String,\n default: 'rgb(var(--white))'\n }\n});\n\n// Get router and notification functionality\nconst router = useRouter();\nconst { notifications, unreadCount, loading, markAllAsRead, getNotifications } = inject('useNotifications')();\n\n// Local state\nconst isOpen = ref(false);\n\n// Computed properties\nconst recentNotifications = computed(() => {\n return notifications.value\n .slice()\n .sort((a, b) => new Date(b.createdAt) - new Date(a.createdAt))\n .slice(0, props.maxNotifications);\n});\n\n// Methods\nconst toggleNotifications = () => {\n isOpen.value = !isOpen.value;\n};\n\nconst closeNotifications = () => {\n isOpen.value = false;\n};\n\nconst handleNotificationClick = (notification) => {\n isOpen.value = false;\n \n if (notification._id) {\n // Handle in store\n actions.handleNotificationAction({\n notificationId: notification._id,\n ...notification.metadata\n });\n }\n};\n\n// Lifecycle hooks\nonMounted(() => {\n // Load notifications when component mounts\n const userId = auth.state.user._id;\n if (userId) {\n getNotifications(userId);\n }\n});\n</script>\n\n<style scoped>\n.notification-badge-container {\n position: relative;\n display: inline-block;\n}\n\n.notification-button {\n background: none;\n border: none;\n cursor: pointer;\n position: relative;\n font-size: 1.2rem;\n}\n\n.notification-icon {\n font-size: 1.4rem;\n}\n\n.button-counter {\n position: absolute;\n right: -8px;\n bottom: -8px;\n background: rgb(var(--fourth));\n color: rgb(var(--white));\n height: 16px;\n border-radius: 16px;\n width: 16px;\n font-weight: 500;\n text-align: center;\n line-height: 16px;\n font-size: 10px;\n}\n\n\n.notifications-loading,\n.notifications-empty {\n padding: 24px;\n text-align: center;\n color: rgb(var(--text-light));\n}\n</style>"],"names":["auth.state"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAuEA,UAAM,QAAQ;AAYC,cAAS;AACxB,UAAM,EAAE,eAAe,aAAa,SAAS,eAAe,qBAAqB,OAAO,kBAAkB,EAAG;AAG7G,UAAM,SAAS,IAAI,KAAK;AAGxB,UAAM,sBAAsB,SAAS,MAAM;AACzC,aAAO,cAAc,MAClB,MAAK,EACL,KAAK,CAAC,GAAG,MAAM,IAAI,KAAK,EAAE,SAAS,IAAI,IAAI,KAAK,EAAE,SAAS,CAAC,EAC5D,MAAM,GAAG,MAAM,gBAAgB;AAAA,IACpC,CAAC;AAGD,UAAM,sBAAsB,MAAM;AAChC,aAAO,QAAQ,CAAC,OAAO;AAAA,IACzB;AAEA,UAAM,qBAAqB,MAAM;AAC/B,aAAO,QAAQ;AAAA,IACjB;AAEA,UAAM,0BAA0B,CAAC,iBAAiB;AAChD,aAAO,QAAQ;AAEf,UAAI,aAAa,KAAK;AAEpB,gBAAQ,yBAAyB;AAAA,UAC/B,gBAAgB,aAAa;AAAA,UAC7B,GAAG,aAAa;AAAA,QACtB,CAAK;AAAA,MACL;AAAA,IACA;AAGA,cAAU,MAAM;AAEd,YAAM,SAASA,MAAW,KAAK;AAC/B,UAAI,QAAQ;AACV,yBAAiB,MAAM;AAAA,MAC3B;AAAA,IACA,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -4,7 +4,7 @@ const vue = require("vue");
4
4
  const vueRouter = require("vue-router");
5
5
  const Button = require("../../../../components/Button/Button.vue2.cjs");
6
6
  const Select = require("../../../../components/Select/Select.vue.cjs");
7
- const Popup = require("../../../../components/Popup/Popup.vue.cjs");
7
+ const Popup = require("../../../../components/Popup/Popup.vue2.cjs");
8
8
  const IconTime = require("../../../icons/entities/IconTime.vue.cjs");
9
9
  const CardOrderItem = require("../blocks/CardOrderItem.vue.cjs");
10
10
  const CardOrganization = require("../../../organizations/components/blocks/CardOrganization.vue.cjs");
@@ -2,7 +2,7 @@ import { ref, onMounted, computed, createElementBlock, createCommentVNode, openB
2
2
  import { useRouter, useRoute } from "vue-router";
3
3
  import _sfc_main$2 from "../../../../components/Button/Button.vue2.js";
4
4
  import Select from "../../../../components/Select/Select.vue.js";
5
- import _sfc_main$1 from "../../../../components/Popup/Popup.vue.js";
5
+ import _sfc_main$1 from "../../../../components/Popup/Popup.vue2.js";
6
6
  import IconTime from "../../../icons/entities/IconTime.vue.js";
7
7
  import _sfc_main$3 from "../blocks/CardOrderItem.vue.js";
8
8
  import _sfc_main$5 from "../../../organizations/components/blocks/CardOrganization.vue.js";
@@ -4,7 +4,7 @@ const vue = require("vue");
4
4
  const vueRouter = require("vue-router");
5
5
  const Button = require("../../../../components/Button/Button.vue2.cjs");
6
6
  const Tab = require("../../../../components/Tab/Tab.vue2.cjs");
7
- const Popup = require("../../../../components/Popup/Popup.vue.cjs");
7
+ const Popup = require("../../../../components/Popup/Popup.vue2.cjs");
8
8
  const Block = require("../../../../components/Block/Block.vue.cjs");
9
9
  const Feed = require("../../../../components/Feed/Feed.vue.cjs");
10
10
  const CardOrderItem = require("../blocks/CardOrderItem.vue.cjs");
@@ -2,7 +2,7 @@ import { computed, ref, onMounted, createElementBlock, openBlock, createVNode, c
2
2
  import { useRoute, useRouter } from "vue-router";
3
3
  import _sfc_main$2 from "../../../../components/Button/Button.vue2.js";
4
4
  import _sfc_main$3 from "../../../../components/Tab/Tab.vue2.js";
5
- import _sfc_main$4 from "../../../../components/Popup/Popup.vue.js";
5
+ import _sfc_main$4 from "../../../../components/Popup/Popup.vue2.js";
6
6
  import _sfc_main$1 from "../../../../components/Block/Block.vue.js";
7
7
  import _sfc_main$5 from "../../../../components/Feed/Feed.vue.js";
8
8
  import _sfc_main$6 from "../blocks/CardOrderItem.vue.js";
@@ -3,7 +3,7 @@ Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toString
3
3
  const vue = require("vue");
4
4
  const vueRouter = require("vue-router");
5
5
  const CardOrderItem = require("../../../orders/components/blocks/CardOrderItem.vue.cjs");
6
- const Chips = require("../../../../components/Chips/Chips.vue.cjs");
6
+ const Chips = require("../../../../components/Chips/Chips.vue2.cjs");
7
7
  const PlaceholderOrganizationPic = require("../../../icons/placeholders/PlaceholderOrganizationPic.vue.cjs");
8
8
  const IconShopcart = require("../../../icons/entities/IconShopcart.vue.cjs");
9
9
  const IconTime = require("../../../icons/entities/IconTime.vue.cjs");
@@ -1,7 +1,7 @@
1
1
  import { createElementBlock, openBlock, createElementVNode, createCommentVNode, createBlock, toDisplayString, withCtx, createVNode, Fragment, renderList, withModifiers } from "vue";
2
2
  import { useRouter } from "vue-router";
3
3
  import _sfc_main$4 from "../../../orders/components/blocks/CardOrderItem.vue.js";
4
- import _sfc_main$1 from "../../../../components/Chips/Chips.vue.js";
4
+ import _sfc_main$1 from "../../../../components/Chips/Chips.vue2.js";
5
5
  import PlaceholderOrganizationPic from "../../../icons/placeholders/PlaceholderOrganizationPic.vue.js";
6
6
  import _sfc_main$3 from "../../../icons/entities/IconShopcart.vue.js";
7
7
  import IconTime from "../../../icons/entities/IconTime.vue.js";
@@ -14,7 +14,7 @@ require("../../../../../../node_modules/.pnpm/@googlemaps_js-api-loader@1.16.8/n
14
14
  ;/* empty css */
15
15
  ;/* empty css */
16
16
  const Button = require("../../../../components/Button/Button.vue2.cjs");
17
- const Popup = require("../../../../components/Popup/Popup.vue.cjs");
17
+ const Popup = require("../../../../components/Popup/Popup.vue2.cjs");
18
18
  const Block = require("../../../../components/Block/Block.vue.cjs");
19
19
  const Feed = require("../../../../components/Feed/Feed.vue.cjs");
20
20
  const IconDelete = require("../../../icons/navigation/IconDelete.vue.cjs");
@@ -12,7 +12,7 @@ import "../../../../../../node_modules/.pnpm/@googlemaps_js-api-loader@1.16.8/no
12
12
  /* empty css */
13
13
  /* empty css */
14
14
  import _sfc_main$1 from "../../../../components/Button/Button.vue2.js";
15
- import _sfc_main$6 from "../../../../components/Popup/Popup.vue.js";
15
+ import _sfc_main$6 from "../../../../components/Popup/Popup.vue2.js";
16
16
  import _sfc_main$2 from "../../../../components/Block/Block.vue.js";
17
17
  import _sfc_main$7 from "../../../../components/Feed/Feed.vue.js";
18
18
  import _sfc_main$5 from "../../../icons/navigation/IconDelete.vue.js";
@@ -5,10 +5,10 @@ const vueRouter = require("vue-router");
5
5
  const Feed = require("../../../../components/Feed/Feed.vue.cjs");
6
6
  ;/* empty css */
7
7
  ;/* empty css */
8
- const Popup = require("../../../../components/Popup/Popup.vue.cjs");
8
+ const Popup = require("../../../../components/Popup/Popup.vue2.cjs");
9
9
  const SectionPageTitle = require("../../../globals/views/components/sections/SectionPageTitle.vue.cjs");
10
10
  const MembersAdd = require("../sections/MembersAdd.vue.cjs");
11
- ;/* empty css */
11
+ ;/* empty css */
12
12
  require("../../../../components/Menu/MenuItem.vue.cjs");
13
13
  const CardUser = require("../../../auth/views/components/blocks/CardUser.vue.cjs");
14
14
  const CardDepartment = require("../blocks/CardDepartment.vue.cjs");