@ozdao/martyrs 0.2.485 → 0.2.487

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 (698) hide show
  1. package/dist/Media-B2jWzwLB.cjs +1 -0
  2. package/dist/{Media-DlUBwVWs.js → Media-DZ5_ItXQ.js} +3 -3
  3. package/dist/_virtual/index.cjs +4 -4
  4. package/dist/_virtual/index.js +4 -4
  5. package/dist/_virtual/index2.cjs +4 -4
  6. package/dist/_virtual/index2.js +4 -4
  7. package/dist/auth.server.cjs +3 -24
  8. package/dist/auth.server.js +2 -23
  9. package/dist/{authJwt-DBB51Iql.cjs → authJwt-D35KyJlE.cjs} +31 -2
  10. package/dist/{authJwt-DcYNNwcr.js → authJwt-DqxhUym0.js} +31 -2
  11. package/dist/chats.server.cjs +1 -1
  12. package/dist/chats.server.js +1 -1
  13. package/dist/community.server.cjs +1 -1
  14. package/dist/community.server.js +1 -1
  15. package/dist/crud-BDIArc5A.cjs +1096 -0
  16. package/dist/crud-DJvpe0aZ.js +1097 -0
  17. package/dist/events.server.cjs +1 -1
  18. package/dist/events.server.js +1 -1
  19. package/dist/files.server.cjs +1 -1
  20. package/dist/files.server.js +1 -1
  21. package/dist/gallery.server.cjs +1 -1
  22. package/dist/gallery.server.js +1 -1
  23. package/dist/globals.server.cjs +3 -322
  24. package/dist/globals.server.js +1 -303
  25. package/dist/globals.websocket-DzvdIBf6.js +306 -0
  26. package/dist/globals.websocket-k6_B1T7k.cjs +322 -0
  27. package/dist/{index-CsJwdsBW.js → index-CVuQC4k1.js} +1 -1
  28. package/dist/{index-YNOkL1mu.cjs → index-DiSKVCaA.cjs} +1 -1
  29. package/dist/main-C6_DPWGX.cjs +11 -0
  30. package/dist/{main-CK6rC5Sz.js → main-nQmkbWsW.js} +2291 -2224
  31. package/dist/martyrs/src/components/Button/{Button.vue2.cjs → Button.vue.cjs} +2 -2
  32. package/dist/martyrs/src/components/Button/{Button.vue2.js.map → Button.vue.cjs.map} +1 -1
  33. package/dist/martyrs/src/components/Button/{Button.vue2.js → Button.vue.js} +2 -2
  34. package/dist/martyrs/src/components/Button/Button.vue.js.map +1 -0
  35. package/dist/martyrs/src/components/{DatePicker → Calendar}/Calendar.vue.cjs +1 -1
  36. package/dist/martyrs/src/components/Calendar/Calendar.vue.cjs.map +1 -0
  37. package/dist/martyrs/src/components/{DatePicker → Calendar}/Calendar.vue.js +1 -1
  38. package/dist/martyrs/src/components/Calendar/Calendar.vue.js.map +1 -0
  39. package/dist/martyrs/src/components/Chips/{Chips.vue2.cjs → Chips.vue.cjs} +2 -2
  40. package/dist/martyrs/src/components/Chips/Chips.vue.cjs.map +1 -0
  41. package/dist/martyrs/src/components/Chips/{Chips.vue2.js → Chips.vue.js} +2 -2
  42. package/dist/martyrs/src/components/Chips/Chips.vue.js.map +1 -0
  43. package/dist/martyrs/src/components/Feed/Feed.vue.cjs +1 -1
  44. package/dist/martyrs/src/components/Feed/Feed.vue.cjs.map +1 -1
  45. package/dist/martyrs/src/components/Feed/Feed.vue.js +1 -1
  46. package/dist/martyrs/src/components/Feed/Feed.vue.js.map +1 -1
  47. package/dist/martyrs/src/components/Field/{Field.vue.cjs → Field.vue2.cjs} +5 -6
  48. package/dist/martyrs/src/components/Field/Field.vue2.cjs.map +1 -0
  49. package/dist/martyrs/src/components/Field/{Field.vue.js → Field.vue2.js} +5 -6
  50. package/dist/martyrs/src/components/Field/Field.vue2.js.map +1 -0
  51. package/dist/martyrs/src/components/FieldBig/FieldBig.vue.cjs +10 -9
  52. package/dist/martyrs/src/components/FieldBig/FieldBig.vue.cjs.map +1 -1
  53. package/dist/martyrs/src/components/FieldBig/FieldBig.vue.js +13 -12
  54. package/dist/martyrs/src/components/FieldBig/FieldBig.vue.js.map +1 -1
  55. package/dist/martyrs/src/components/FieldPhone/FieldPhone.vue.cjs +1 -1
  56. package/dist/martyrs/src/components/FieldPhone/FieldPhone.vue.cjs.map +1 -1
  57. package/dist/martyrs/src/components/FieldPhone/FieldPhone.vue.js +1 -1
  58. package/dist/martyrs/src/components/FieldPhone/FieldPhone.vue.js.map +1 -1
  59. package/dist/martyrs/src/components/FieldTags/FieldTags.vue.cjs +1 -1
  60. package/dist/martyrs/src/components/FieldTags/FieldTags.vue.js +1 -1
  61. package/dist/martyrs/src/components/Media/Media.vue.cjs +2 -2
  62. package/dist/martyrs/src/components/Media/Media.vue.cjs.map +1 -1
  63. package/dist/martyrs/src/components/Media/Media.vue.js +2 -2
  64. package/dist/martyrs/src/components/Media/Media.vue.js.map +1 -1
  65. package/dist/martyrs/src/components/Menu/{Menu.vue2.cjs → Menu.vue.cjs} +2 -2
  66. package/dist/martyrs/src/components/Menu/Menu.vue.cjs.map +1 -0
  67. package/dist/martyrs/src/components/Menu/{Menu.vue2.js → Menu.vue.js} +2 -2
  68. package/dist/martyrs/src/components/Menu/Menu.vue.js.map +1 -0
  69. package/dist/martyrs/src/components/Popup/{Popup.vue2.cjs → Popup.vue.cjs} +2 -2
  70. package/dist/martyrs/src/components/Popup/{Popup.vue2.js.map → Popup.vue.cjs.map} +1 -1
  71. package/dist/martyrs/src/components/Popup/{Popup.vue2.js → Popup.vue.js} +2 -2
  72. package/dist/martyrs/src/components/Popup/Popup.vue.js.map +1 -0
  73. package/dist/martyrs/src/components/Select/Select.vue.cjs +2 -2
  74. package/dist/martyrs/src/components/Select/Select.vue.cjs.map +1 -1
  75. package/dist/martyrs/src/components/Select/Select.vue.js +2 -2
  76. package/dist/martyrs/src/components/Select/Select.vue.js.map +1 -1
  77. package/dist/martyrs/src/modules/auth/views/components/pages/EnterCode.vue.cjs +1 -0
  78. package/dist/martyrs/src/modules/auth/views/components/pages/EnterCode.vue.cjs.map +1 -1
  79. package/dist/martyrs/src/modules/auth/views/components/pages/EnterCode.vue.js +1 -0
  80. package/dist/martyrs/src/modules/auth/views/components/pages/EnterCode.vue.js.map +1 -1
  81. package/dist/martyrs/src/modules/auth/views/components/pages/EnterPassword.vue.cjs +2 -2
  82. package/dist/martyrs/src/modules/auth/views/components/pages/EnterPassword.vue.js +5 -5
  83. package/dist/martyrs/src/modules/auth/views/components/pages/Invite.vue.cjs +2 -2
  84. package/dist/martyrs/src/modules/auth/views/components/pages/Invite.vue.js +5 -5
  85. package/dist/martyrs/src/modules/auth/views/components/pages/Profile.vue.cjs +3 -2
  86. package/dist/martyrs/src/modules/auth/views/components/pages/Profile.vue.cjs.map +1 -1
  87. package/dist/martyrs/src/modules/auth/views/components/pages/Profile.vue.js +3 -2
  88. package/dist/martyrs/src/modules/auth/views/components/pages/Profile.vue.js.map +1 -1
  89. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEdit.vue.cjs +1 -1
  90. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEdit.vue.js +1 -1
  91. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditAccount.vue.cjs +1 -1
  92. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditAccount.vue.js +1 -1
  93. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditProfile.vue.cjs +2 -2
  94. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditProfile.vue.js +10 -10
  95. package/dist/martyrs/src/modules/auth/views/components/pages/ResetPassword.vue.cjs +2 -2
  96. package/dist/martyrs/src/modules/auth/views/components/pages/ResetPassword.vue.js +4 -4
  97. package/dist/martyrs/src/modules/auth/views/components/pages/SignIn.vue.cjs +2 -2
  98. package/dist/martyrs/src/modules/auth/views/components/pages/SignIn.vue.js +5 -5
  99. package/dist/martyrs/src/modules/auth/views/components/pages/SignUp.vue.cjs +2 -2
  100. package/dist/martyrs/src/modules/auth/views/components/pages/SignUp.vue.js +4 -4
  101. package/dist/martyrs/src/modules/auth/views/components/sections/ProfileEditCredentials.vue.cjs +2 -2
  102. package/dist/martyrs/src/modules/auth/views/components/sections/ProfileEditCredentials.vue.js +23 -23
  103. package/dist/martyrs/src/modules/community/components/blocks/CardBlogpost.vue.cjs +1 -1
  104. package/dist/martyrs/src/modules/community/components/blocks/CardBlogpost.vue.js +1 -1
  105. package/dist/martyrs/src/modules/community/components/pages/BlogPost.vue.cjs +3 -3
  106. package/dist/martyrs/src/modules/community/components/pages/BlogPost.vue.js +3 -3
  107. package/dist/martyrs/src/modules/community/components/pages/CreateBlogPost.vue.cjs +4 -4
  108. package/dist/martyrs/src/modules/community/components/pages/CreateBlogPost.vue.js +13 -13
  109. package/dist/martyrs/src/modules/constructor/components/elements/Card.vue.cjs +1 -1
  110. package/dist/martyrs/src/modules/constructor/components/elements/Card.vue.js +3 -3
  111. package/dist/martyrs/src/modules/constructor/components/elements/Embed.vue.cjs +1 -1
  112. package/dist/martyrs/src/modules/constructor/components/elements/Embed.vue.js +2 -2
  113. package/dist/martyrs/src/modules/events/components/blocks/CardEvent.vue.cjs +1 -1
  114. package/dist/martyrs/src/modules/events/components/blocks/CardEvent.vue.js +1 -1
  115. package/dist/martyrs/src/modules/events/components/elements/ButtonCheck.vue.cjs +1 -1
  116. package/dist/martyrs/src/modules/events/components/elements/ButtonCheck.vue.js +1 -1
  117. package/dist/martyrs/src/modules/events/components/elements/ButtonJoin.vue.cjs +1 -1
  118. package/dist/martyrs/src/modules/events/components/elements/ButtonJoin.vue.js +1 -1
  119. package/dist/martyrs/src/modules/events/components/pages/EditEvent.vue.cjs +3 -3
  120. package/dist/martyrs/src/modules/events/components/pages/EditEvent.vue.cjs.map +1 -1
  121. package/dist/martyrs/src/modules/events/components/pages/EditEvent.vue.js +25 -25
  122. package/dist/martyrs/src/modules/events/components/pages/EditEvent.vue.js.map +1 -1
  123. package/dist/martyrs/src/modules/events/components/pages/EditEventTickets.vue.cjs +3 -3
  124. package/dist/martyrs/src/modules/events/components/pages/EditEventTickets.vue.js +16 -16
  125. package/dist/martyrs/src/modules/events/components/pages/Event.vue.cjs +9 -2
  126. package/dist/martyrs/src/modules/events/components/pages/Event.vue.cjs.map +1 -1
  127. package/dist/martyrs/src/modules/events/components/pages/Event.vue.js +9 -2
  128. package/dist/martyrs/src/modules/events/components/pages/Event.vue.js.map +1 -1
  129. package/dist/martyrs/src/modules/events/components/pages/Events.vue.cjs +1 -1
  130. package/dist/martyrs/src/modules/events/components/pages/Events.vue.js +1 -1
  131. package/dist/martyrs/src/modules/gallery/components/pages/Gallery.vue.cjs +1 -1
  132. package/dist/martyrs/src/modules/gallery/components/pages/Gallery.vue.js +1 -1
  133. package/dist/martyrs/src/modules/gallery/components/sections/BackofficeGallery.vue.cjs +4 -3
  134. package/dist/martyrs/src/modules/gallery/components/sections/BackofficeGallery.vue.cjs.map +1 -1
  135. package/dist/martyrs/src/modules/gallery/components/sections/BackofficeGallery.vue.js +4 -3
  136. package/dist/martyrs/src/modules/gallery/components/sections/BackofficeGallery.vue.js.map +1 -1
  137. package/dist/martyrs/src/modules/globals/views/classes/globals.i18n.cjs +1 -1
  138. package/dist/martyrs/src/modules/globals/views/classes/globals.i18n.js +1 -1
  139. package/dist/martyrs/src/modules/globals/views/classes/globals.store.cjs +24 -58
  140. package/dist/martyrs/src/modules/globals/views/classes/globals.store.cjs.map +1 -1
  141. package/dist/martyrs/src/modules/globals/views/classes/globals.store.js +24 -58
  142. package/dist/martyrs/src/modules/globals/views/classes/globals.store.js.map +1 -1
  143. package/dist/martyrs/src/modules/globals/views/components/blocks/AlertDialog.vue.cjs +1 -1
  144. package/dist/martyrs/src/modules/globals/views/components/blocks/AlertDialog.vue.js +1 -1
  145. package/dist/martyrs/src/modules/globals/views/components/blocks/BlockSearch.vue.cjs +1 -1
  146. package/dist/martyrs/src/modules/globals/views/components/blocks/BlockSearch.vue.js +2 -2
  147. package/dist/martyrs/src/modules/globals/views/components/blocks/CardHeader.vue.cjs +1 -1
  148. package/dist/martyrs/src/modules/globals/views/components/blocks/CardHeader.vue.js +1 -1
  149. package/dist/martyrs/src/modules/globals/views/components/blocks/PopupAuth.vue.cjs +2 -2
  150. package/dist/martyrs/src/modules/globals/views/components/blocks/PopupAuth.vue.js +2 -2
  151. package/dist/martyrs/src/modules/globals/views/components/blocks/PopupDateSelector.vue.cjs +3 -3
  152. package/dist/martyrs/src/modules/globals/views/components/blocks/PopupDateSelector.vue.cjs.map +1 -1
  153. package/dist/martyrs/src/modules/globals/views/components/blocks/PopupDateSelector.vue.js +3 -3
  154. package/dist/martyrs/src/modules/globals/views/components/blocks/PopupDateSelector.vue.js.map +1 -1
  155. package/dist/martyrs/src/modules/globals/views/components/layouts/Client.vue.cjs +2 -2
  156. package/dist/martyrs/src/modules/globals/views/components/layouts/Client.vue.js +2 -2
  157. package/dist/martyrs/src/modules/globals/views/components/partials/Header.vue.cjs +1 -1
  158. package/dist/martyrs/src/modules/globals/views/components/partials/Header.vue.js +1 -1
  159. package/dist/martyrs/src/modules/globals/views/components/partials/NavigationBar.vue.cjs +1 -1
  160. package/dist/martyrs/src/modules/globals/views/components/partials/NavigationBar.vue.js +1 -1
  161. package/dist/martyrs/src/modules/globals/views/components/sections/Filters.vue2.cjs +2 -1
  162. package/dist/martyrs/src/modules/globals/views/components/sections/Filters.vue2.cjs.map +1 -1
  163. package/dist/martyrs/src/modules/globals/views/components/sections/Filters.vue2.js +2 -1
  164. package/dist/martyrs/src/modules/globals/views/components/sections/Filters.vue2.js.map +1 -1
  165. package/dist/martyrs/src/modules/globals/views/components/sections/filters/FilterOptions.vue.cjs +1 -1
  166. package/dist/martyrs/src/modules/globals/views/components/sections/filters/FilterOptions.vue.js +2 -2
  167. package/dist/martyrs/src/modules/globals/views/components/sections/filters/FilterPrice.vue.cjs +1 -1
  168. package/dist/martyrs/src/modules/globals/views/components/sections/filters/FilterPrice.vue.js +3 -3
  169. package/dist/martyrs/src/modules/globals/views/store/globals.cjs +6 -0
  170. package/dist/martyrs/src/modules/globals/views/store/globals.cjs.map +1 -1
  171. package/dist/martyrs/src/modules/globals/views/store/globals.js +6 -0
  172. package/dist/martyrs/src/modules/globals/views/store/globals.js.map +1 -1
  173. package/dist/martyrs/src/modules/globals/views/utils/axios-instance.cjs.map +1 -1
  174. package/dist/martyrs/src/modules/globals/views/utils/axios-instance.js.map +1 -1
  175. package/dist/martyrs/src/modules/globals/views/utils/query-serializer.cjs +100 -0
  176. package/dist/martyrs/src/modules/globals/views/utils/query-serializer.cjs.map +1 -0
  177. package/dist/martyrs/src/modules/globals/views/utils/query-serializer.js +100 -0
  178. package/dist/martyrs/src/modules/globals/views/utils/query-serializer.js.map +1 -0
  179. package/dist/martyrs/src/modules/icons/components/IconSearchPopup.vue.cjs +224 -0
  180. package/dist/martyrs/src/modules/icons/components/IconSearchPopup.vue.cjs.map +1 -0
  181. package/dist/martyrs/src/modules/icons/components/IconSearchPopup.vue.js +224 -0
  182. package/dist/martyrs/src/modules/icons/components/IconSearchPopup.vue.js.map +1 -0
  183. package/dist/martyrs/src/modules/icons/entities/IconAddress.vue.cjs +40 -0
  184. package/dist/martyrs/src/modules/icons/entities/IconAddress.vue.cjs.map +1 -0
  185. package/dist/martyrs/src/modules/icons/entities/IconAddress.vue.js +40 -0
  186. package/dist/martyrs/src/modules/icons/entities/IconAddress.vue.js.map +1 -0
  187. package/dist/martyrs/src/modules/icons/entities/IconDate.vue.cjs +6 -6
  188. package/dist/martyrs/src/modules/icons/entities/IconDate.vue.js +6 -6
  189. package/dist/martyrs/src/modules/icons/entities/IconEmail.vue.cjs +32 -0
  190. package/dist/martyrs/src/modules/icons/entities/IconEmail.vue.cjs.map +1 -0
  191. package/dist/martyrs/src/modules/icons/entities/IconEmail.vue.js +32 -0
  192. package/dist/martyrs/src/modules/icons/entities/IconEmail.vue.js.map +1 -0
  193. package/dist/martyrs/src/modules/icons/entities/IconMusic.vue.cjs +10 -12
  194. package/dist/martyrs/src/modules/icons/entities/IconMusic.vue.cjs.map +1 -1
  195. package/dist/martyrs/src/modules/icons/entities/IconMusic.vue.js +11 -13
  196. package/dist/martyrs/src/modules/icons/entities/IconMusic.vue.js.map +1 -1
  197. package/dist/martyrs/src/modules/icons/entities/IconPhone.vue.cjs +32 -0
  198. package/dist/martyrs/src/modules/icons/entities/IconPhone.vue.cjs.map +1 -0
  199. package/dist/martyrs/src/modules/icons/entities/IconPhone.vue.js +32 -0
  200. package/dist/martyrs/src/modules/icons/entities/IconPhone.vue.js.map +1 -0
  201. package/dist/martyrs/src/modules/icons/icons.client.cjs +48 -4
  202. package/dist/martyrs/src/modules/icons/icons.client.cjs.map +1 -1
  203. package/dist/martyrs/src/modules/icons/icons.client.js +172 -128
  204. package/dist/martyrs/src/modules/icons/icons.client.js.map +1 -1
  205. package/dist/martyrs/src/modules/icons/navigation/IconCross.vue.cjs +5 -7
  206. package/dist/martyrs/src/modules/icons/navigation/IconCross.vue.cjs.map +1 -1
  207. package/dist/martyrs/src/modules/icons/navigation/IconCross.vue.js +5 -7
  208. package/dist/martyrs/src/modules/icons/navigation/IconCross.vue.js.map +1 -1
  209. package/dist/martyrs/src/modules/icons/navigation/IconPause.vue.cjs +6 -11
  210. package/dist/martyrs/src/modules/icons/navigation/IconPause.vue.cjs.map +1 -1
  211. package/dist/martyrs/src/modules/icons/navigation/IconPause.vue.js +6 -11
  212. package/dist/martyrs/src/modules/icons/navigation/IconPause.vue.js.map +1 -1
  213. package/dist/martyrs/src/modules/icons/navigation/IconRefresh.vue.cjs +6 -11
  214. package/dist/martyrs/src/modules/icons/navigation/IconRefresh.vue.cjs.map +1 -1
  215. package/dist/martyrs/src/modules/icons/navigation/IconRefresh.vue.js +6 -11
  216. package/dist/martyrs/src/modules/icons/navigation/IconRefresh.vue.js.map +1 -1
  217. package/dist/martyrs/src/modules/icons/pages/IconsPage.vue.cjs +62 -6
  218. package/dist/martyrs/src/modules/icons/pages/IconsPage.vue.cjs.map +1 -1
  219. package/dist/martyrs/src/modules/icons/pages/IconsPage.vue.js +189 -133
  220. package/dist/martyrs/src/modules/icons/pages/IconsPage.vue.js.map +1 -1
  221. package/dist/martyrs/src/modules/icons/socials/dribbble.vue.cjs +21 -12
  222. package/dist/martyrs/src/modules/icons/socials/dribbble.vue.cjs.map +1 -1
  223. package/dist/martyrs/src/modules/icons/socials/dribbble.vue.js +21 -12
  224. package/dist/martyrs/src/modules/icons/socials/dribbble.vue.js.map +1 -1
  225. package/dist/martyrs/src/modules/icons/socials/facebook.vue.cjs +21 -12
  226. package/dist/martyrs/src/modules/icons/socials/facebook.vue.cjs.map +1 -1
  227. package/dist/martyrs/src/modules/icons/socials/facebook.vue.js +21 -12
  228. package/dist/martyrs/src/modules/icons/socials/facebook.vue.js.map +1 -1
  229. package/dist/martyrs/src/modules/icons/socials/instagram.vue.cjs +25 -17
  230. package/dist/martyrs/src/modules/icons/socials/instagram.vue.cjs.map +1 -1
  231. package/dist/martyrs/src/modules/icons/socials/instagram.vue.js +25 -17
  232. package/dist/martyrs/src/modules/icons/socials/instagram.vue.js.map +1 -1
  233. package/dist/martyrs/src/modules/icons/socials/line.vue.cjs +23 -14
  234. package/dist/martyrs/src/modules/icons/socials/line.vue.cjs.map +1 -1
  235. package/dist/martyrs/src/modules/icons/socials/line.vue.js +23 -14
  236. package/dist/martyrs/src/modules/icons/socials/line.vue.js.map +1 -1
  237. package/dist/martyrs/src/modules/icons/socials/linkedin.vue.cjs +26 -17
  238. package/dist/martyrs/src/modules/icons/socials/linkedin.vue.cjs.map +1 -1
  239. package/dist/martyrs/src/modules/icons/socials/linkedin.vue.js +26 -17
  240. package/dist/martyrs/src/modules/icons/socials/linkedin.vue.js.map +1 -1
  241. package/dist/martyrs/src/modules/icons/socials/reddit.vue.cjs +21 -12
  242. package/dist/martyrs/src/modules/icons/socials/reddit.vue.cjs.map +1 -1
  243. package/dist/martyrs/src/modules/icons/socials/reddit.vue.js +21 -12
  244. package/dist/martyrs/src/modules/icons/socials/reddit.vue.js.map +1 -1
  245. package/dist/martyrs/src/modules/icons/socials/telegram.vue.cjs +29 -20
  246. package/dist/martyrs/src/modules/icons/socials/telegram.vue.cjs.map +1 -1
  247. package/dist/martyrs/src/modules/icons/socials/telegram.vue.js +29 -20
  248. package/dist/martyrs/src/modules/icons/socials/telegram.vue.js.map +1 -1
  249. package/dist/martyrs/src/modules/icons/socials/twitter.vue.cjs +21 -12
  250. package/dist/martyrs/src/modules/icons/socials/twitter.vue.cjs.map +1 -1
  251. package/dist/martyrs/src/modules/icons/socials/twitter.vue.js +21 -12
  252. package/dist/martyrs/src/modules/icons/socials/twitter.vue.js.map +1 -1
  253. package/dist/martyrs/src/modules/icons/socials/vk.vue.cjs +21 -12
  254. package/dist/martyrs/src/modules/icons/socials/vk.vue.cjs.map +1 -1
  255. package/dist/martyrs/src/modules/icons/socials/vk.vue.js +21 -12
  256. package/dist/martyrs/src/modules/icons/socials/vk.vue.js.map +1 -1
  257. package/dist/martyrs/src/modules/icons/socials/whatsapp.vue.cjs +32 -0
  258. package/dist/martyrs/src/modules/icons/socials/whatsapp.vue.cjs.map +1 -0
  259. package/dist/martyrs/src/modules/icons/socials/whatsapp.vue.js +32 -0
  260. package/dist/martyrs/src/modules/icons/socials/whatsapp.vue.js.map +1 -0
  261. package/dist/martyrs/src/modules/icons/socials/youtube.vue.cjs +21 -12
  262. package/dist/martyrs/src/modules/icons/socials/youtube.vue.cjs.map +1 -1
  263. package/dist/martyrs/src/modules/icons/socials/youtube.vue.js +21 -12
  264. package/dist/martyrs/src/modules/icons/socials/youtube.vue.js.map +1 -1
  265. package/dist/martyrs/src/modules/music/components/cards/AlbumCard.vue.cjs +87 -0
  266. package/dist/martyrs/src/modules/music/components/cards/AlbumCard.vue.cjs.map +1 -0
  267. package/dist/martyrs/src/modules/music/components/cards/AlbumCard.vue.js +87 -0
  268. package/dist/martyrs/src/modules/music/components/cards/AlbumCard.vue.js.map +1 -0
  269. package/dist/martyrs/src/modules/music/components/cards/ArtistCard.vue.cjs +83 -0
  270. package/dist/martyrs/src/modules/music/components/cards/ArtistCard.vue.cjs.map +1 -0
  271. package/dist/martyrs/src/modules/music/components/cards/ArtistCard.vue.js +83 -0
  272. package/dist/martyrs/src/modules/music/components/cards/ArtistCard.vue.js.map +1 -0
  273. package/dist/martyrs/src/modules/music/components/cards/PlaylistCard.vue.cjs +83 -0
  274. package/dist/martyrs/src/modules/music/components/cards/PlaylistCard.vue.cjs.map +1 -0
  275. package/dist/martyrs/src/modules/music/components/cards/PlaylistCard.vue.js +83 -0
  276. package/dist/martyrs/src/modules/music/components/cards/PlaylistCard.vue.js.map +1 -0
  277. package/dist/martyrs/src/modules/music/components/cards/TrackCard.vue.cjs +68 -0
  278. package/dist/martyrs/src/modules/music/components/cards/TrackCard.vue.cjs.map +1 -0
  279. package/dist/martyrs/src/modules/music/components/cards/TrackCard.vue.js +68 -0
  280. package/dist/martyrs/src/modules/music/components/cards/TrackCard.vue.js.map +1 -0
  281. package/dist/martyrs/src/modules/music/components/cards/TrackListCard.vue.cjs +162 -0
  282. package/dist/martyrs/src/modules/music/components/cards/TrackListCard.vue.cjs.map +1 -0
  283. package/dist/martyrs/src/modules/music/components/cards/TrackListCard.vue.js +162 -0
  284. package/dist/martyrs/src/modules/music/components/cards/TrackListCard.vue.js.map +1 -0
  285. package/dist/martyrs/src/modules/music/components/forms/AlbumForm.vue.cjs +437 -0
  286. package/dist/martyrs/src/modules/music/components/forms/AlbumForm.vue.cjs.map +1 -0
  287. package/dist/martyrs/src/modules/music/components/forms/AlbumForm.vue.js +437 -0
  288. package/dist/martyrs/src/modules/music/components/forms/AlbumForm.vue.js.map +1 -0
  289. package/dist/martyrs/src/modules/music/components/forms/ArtistForm.vue.cjs +416 -0
  290. package/dist/martyrs/src/modules/music/components/forms/ArtistForm.vue.cjs.map +1 -0
  291. package/dist/martyrs/src/modules/music/components/forms/ArtistForm.vue.js +416 -0
  292. package/dist/martyrs/src/modules/music/components/forms/ArtistForm.vue.js.map +1 -0
  293. package/dist/martyrs/src/modules/music/components/forms/PlaylistForm.vue.cjs +174 -0
  294. package/dist/martyrs/src/modules/music/components/forms/PlaylistForm.vue.cjs.map +1 -0
  295. package/dist/martyrs/src/modules/music/components/forms/PlaylistForm.vue.js +174 -0
  296. package/dist/martyrs/src/modules/music/components/forms/PlaylistForm.vue.js.map +1 -0
  297. package/dist/martyrs/src/modules/music/components/forms/SearchForm.vue.cjs +80 -0
  298. package/dist/martyrs/src/modules/music/components/forms/SearchForm.vue.cjs.map +1 -0
  299. package/dist/martyrs/src/modules/music/components/forms/SearchForm.vue.js +80 -0
  300. package/dist/martyrs/src/modules/music/components/forms/SearchForm.vue.js.map +1 -0
  301. package/dist/martyrs/src/modules/music/components/forms/TrackForm.vue.cjs +554 -0
  302. package/dist/martyrs/src/modules/music/components/forms/TrackForm.vue.cjs.map +1 -0
  303. package/dist/martyrs/src/modules/music/components/forms/TrackForm.vue.js +554 -0
  304. package/dist/martyrs/src/modules/music/components/forms/TrackForm.vue.js.map +1 -0
  305. package/dist/martyrs/src/modules/music/components/layouts/MusicLayout.vue.cjs +104 -0
  306. package/dist/martyrs/src/modules/music/components/layouts/MusicLayout.vue.cjs.map +1 -0
  307. package/dist/martyrs/src/modules/music/components/layouts/MusicLayout.vue.js +104 -0
  308. package/dist/martyrs/src/modules/music/components/layouts/MusicLayout.vue.js.map +1 -0
  309. package/dist/martyrs/src/modules/music/components/pages/Album.vue.cjs +314 -0
  310. package/dist/martyrs/src/modules/music/components/pages/Album.vue.cjs.map +1 -0
  311. package/dist/martyrs/src/modules/music/components/pages/Album.vue.js +314 -0
  312. package/dist/martyrs/src/modules/music/components/pages/Album.vue.js.map +1 -0
  313. package/dist/martyrs/src/modules/music/components/pages/AlbumCreate.vue.cjs +14 -0
  314. package/dist/martyrs/src/modules/music/components/pages/AlbumCreate.vue.cjs.map +1 -0
  315. package/dist/martyrs/src/modules/music/components/pages/AlbumCreate.vue.js +14 -0
  316. package/dist/martyrs/src/modules/music/components/pages/AlbumCreate.vue.js.map +1 -0
  317. package/dist/martyrs/src/modules/music/components/pages/AlbumEdit.vue.cjs +23 -0
  318. package/dist/martyrs/src/modules/music/components/pages/AlbumEdit.vue.cjs.map +1 -0
  319. package/dist/martyrs/src/modules/music/components/pages/AlbumEdit.vue.js +23 -0
  320. package/dist/martyrs/src/modules/music/components/pages/AlbumEdit.vue.js.map +1 -0
  321. package/dist/martyrs/src/modules/music/components/pages/Artist.vue.cjs +467 -0
  322. package/dist/martyrs/src/modules/music/components/pages/Artist.vue.cjs.map +1 -0
  323. package/dist/martyrs/src/modules/music/components/pages/Artist.vue.js +467 -0
  324. package/dist/martyrs/src/modules/music/components/pages/Artist.vue.js.map +1 -0
  325. package/dist/martyrs/src/modules/music/components/pages/ArtistCreate.vue.cjs +14 -0
  326. package/dist/martyrs/src/modules/music/components/pages/ArtistCreate.vue.cjs.map +1 -0
  327. package/dist/martyrs/src/modules/music/components/pages/ArtistCreate.vue.js +14 -0
  328. package/dist/martyrs/src/modules/music/components/pages/ArtistCreate.vue.js.map +1 -0
  329. package/dist/martyrs/src/modules/music/components/pages/ArtistEdit.vue.cjs +23 -0
  330. package/dist/martyrs/src/modules/music/components/pages/ArtistEdit.vue.cjs.map +1 -0
  331. package/dist/martyrs/src/modules/music/components/pages/ArtistEdit.vue.js +23 -0
  332. package/dist/martyrs/src/modules/music/components/pages/ArtistEdit.vue.js.map +1 -0
  333. package/dist/martyrs/src/modules/music/components/pages/MusicHome.vue.cjs +256 -0
  334. package/dist/martyrs/src/modules/music/components/pages/MusicHome.vue.cjs.map +1 -0
  335. package/dist/martyrs/src/modules/music/components/pages/MusicHome.vue.js +256 -0
  336. package/dist/martyrs/src/modules/music/components/pages/MusicHome.vue.js.map +1 -0
  337. package/dist/martyrs/src/modules/music/components/pages/MusicLibrary.vue.cjs +248 -0
  338. package/dist/martyrs/src/modules/music/components/pages/MusicLibrary.vue.cjs.map +1 -0
  339. package/dist/martyrs/src/modules/music/components/pages/MusicLibrary.vue.js +248 -0
  340. package/dist/martyrs/src/modules/music/components/pages/MusicLibrary.vue.js.map +1 -0
  341. package/dist/martyrs/src/modules/music/components/pages/Playlist.vue.cjs +580 -0
  342. package/dist/martyrs/src/modules/music/components/pages/Playlist.vue.cjs.map +1 -0
  343. package/dist/martyrs/src/modules/music/components/pages/Playlist.vue.js +580 -0
  344. package/dist/martyrs/src/modules/music/components/pages/Playlist.vue.js.map +1 -0
  345. package/dist/martyrs/src/modules/music/components/pages/PlaylistCreate.vue.cjs +14 -0
  346. package/dist/martyrs/src/modules/music/components/pages/PlaylistCreate.vue.cjs.map +1 -0
  347. package/dist/martyrs/src/modules/music/components/pages/PlaylistCreate.vue.js +14 -0
  348. package/dist/martyrs/src/modules/music/components/pages/PlaylistCreate.vue.js.map +1 -0
  349. package/dist/martyrs/src/modules/music/components/pages/PlaylistEdit.vue.cjs +23 -0
  350. package/dist/martyrs/src/modules/music/components/pages/PlaylistEdit.vue.cjs.map +1 -0
  351. package/dist/martyrs/src/modules/music/components/pages/PlaylistEdit.vue.js +23 -0
  352. package/dist/martyrs/src/modules/music/components/pages/PlaylistEdit.vue.js.map +1 -0
  353. package/dist/martyrs/src/modules/music/components/pages/SearchResults.vue.cjs +473 -0
  354. package/dist/martyrs/src/modules/music/components/pages/SearchResults.vue.cjs.map +1 -0
  355. package/dist/martyrs/src/modules/music/components/pages/SearchResults.vue.js +473 -0
  356. package/dist/martyrs/src/modules/music/components/pages/SearchResults.vue.js.map +1 -0
  357. package/dist/martyrs/src/modules/music/components/pages/Track.vue.cjs +111 -0
  358. package/dist/martyrs/src/modules/music/components/pages/Track.vue.cjs.map +1 -0
  359. package/dist/martyrs/src/modules/music/components/pages/Track.vue.js +111 -0
  360. package/dist/martyrs/src/modules/music/components/pages/Track.vue.js.map +1 -0
  361. package/dist/martyrs/src/modules/music/components/pages/TrackCreate.vue.cjs +28 -0
  362. package/dist/martyrs/src/modules/music/components/pages/TrackCreate.vue.cjs.map +1 -0
  363. package/dist/martyrs/src/modules/music/components/pages/TrackCreate.vue.js +28 -0
  364. package/dist/martyrs/src/modules/music/components/pages/TrackCreate.vue.js.map +1 -0
  365. package/dist/martyrs/src/modules/music/components/pages/TrackEdit.vue.cjs +23 -0
  366. package/dist/martyrs/src/modules/music/components/pages/TrackEdit.vue.cjs.map +1 -0
  367. package/dist/martyrs/src/modules/music/components/pages/TrackEdit.vue.js +23 -0
  368. package/dist/martyrs/src/modules/music/components/pages/TrackEdit.vue.js.map +1 -0
  369. package/dist/martyrs/src/modules/music/components/player/MusicPlayer.vue.cjs +227 -0
  370. package/dist/martyrs/src/modules/music/components/player/MusicPlayer.vue.cjs.map +1 -0
  371. package/dist/martyrs/src/modules/music/components/player/MusicPlayer.vue.js +227 -0
  372. package/dist/martyrs/src/modules/music/components/player/MusicPlayer.vue.js.map +1 -0
  373. package/dist/martyrs/src/modules/music/components/player/TrackProgress.vue.cjs +85 -0
  374. package/dist/martyrs/src/modules/music/components/player/TrackProgress.vue.cjs.map +1 -0
  375. package/dist/martyrs/src/modules/music/components/player/TrackProgress.vue.js +85 -0
  376. package/dist/martyrs/src/modules/music/components/player/TrackProgress.vue.js.map +1 -0
  377. package/dist/martyrs/src/modules/music/components/player/VolumeControl.vue.cjs +71 -0
  378. package/dist/martyrs/src/modules/music/components/player/VolumeControl.vue.cjs.map +1 -0
  379. package/dist/martyrs/src/modules/music/components/player/VolumeControl.vue.js +71 -0
  380. package/dist/martyrs/src/modules/music/components/player/VolumeControl.vue.js.map +1 -0
  381. package/dist/martyrs/src/modules/music/music.client.cjs +137 -0
  382. package/dist/martyrs/src/modules/music/music.client.cjs.map +1 -0
  383. package/dist/martyrs/src/modules/music/music.client.js +137 -0
  384. package/dist/martyrs/src/modules/music/music.client.js.map +1 -0
  385. package/dist/martyrs/src/modules/music/router/albums.cjs +34 -0
  386. package/dist/martyrs/src/modules/music/router/albums.cjs.map +1 -0
  387. package/dist/martyrs/src/modules/music/router/albums.js +34 -0
  388. package/dist/martyrs/src/modules/music/router/albums.js.map +1 -0
  389. package/dist/martyrs/src/modules/music/router/artists.cjs +34 -0
  390. package/dist/martyrs/src/modules/music/router/artists.cjs.map +1 -0
  391. package/dist/martyrs/src/modules/music/router/artists.js +34 -0
  392. package/dist/martyrs/src/modules/music/router/artists.js.map +1 -0
  393. package/dist/martyrs/src/modules/music/router/music.cjs +47 -0
  394. package/dist/martyrs/src/modules/music/router/music.cjs.map +1 -0
  395. package/dist/martyrs/src/modules/music/router/music.js +47 -0
  396. package/dist/martyrs/src/modules/music/router/music.js.map +1 -0
  397. package/dist/martyrs/src/modules/music/router/playlists.cjs +34 -0
  398. package/dist/martyrs/src/modules/music/router/playlists.cjs.map +1 -0
  399. package/dist/martyrs/src/modules/music/router/playlists.js +34 -0
  400. package/dist/martyrs/src/modules/music/router/playlists.js.map +1 -0
  401. package/dist/martyrs/src/modules/music/router/tracks.cjs +34 -0
  402. package/dist/martyrs/src/modules/music/router/tracks.cjs.map +1 -0
  403. package/dist/martyrs/src/modules/music/router/tracks.js +34 -0
  404. package/dist/martyrs/src/modules/music/router/tracks.js.map +1 -0
  405. package/dist/martyrs/src/modules/music/store/albums.cjs +167 -0
  406. package/dist/martyrs/src/modules/music/store/albums.cjs.map +1 -0
  407. package/dist/martyrs/src/modules/music/store/albums.js +167 -0
  408. package/dist/martyrs/src/modules/music/store/albums.js.map +1 -0
  409. package/dist/martyrs/src/modules/music/store/artists.cjs +160 -0
  410. package/dist/martyrs/src/modules/music/store/artists.cjs.map +1 -0
  411. package/dist/martyrs/src/modules/music/store/artists.js +160 -0
  412. package/dist/martyrs/src/modules/music/store/artists.js.map +1 -0
  413. package/dist/martyrs/src/modules/music/store/genres.cjs +123 -0
  414. package/dist/martyrs/src/modules/music/store/genres.cjs.map +1 -0
  415. package/dist/martyrs/src/modules/music/store/genres.js +123 -0
  416. package/dist/martyrs/src/modules/music/store/genres.js.map +1 -0
  417. package/dist/martyrs/src/modules/music/store/player.cjs +297 -0
  418. package/dist/martyrs/src/modules/music/store/player.cjs.map +1 -0
  419. package/dist/martyrs/src/modules/music/store/player.js +297 -0
  420. package/dist/martyrs/src/modules/music/store/player.js.map +1 -0
  421. package/dist/martyrs/src/modules/music/store/playlists.cjs +182 -0
  422. package/dist/martyrs/src/modules/music/store/playlists.cjs.map +1 -0
  423. package/dist/martyrs/src/modules/music/store/playlists.js +182 -0
  424. package/dist/martyrs/src/modules/music/store/playlists.js.map +1 -0
  425. package/dist/martyrs/src/modules/music/store/search.cjs +109 -0
  426. package/dist/martyrs/src/modules/music/store/search.cjs.map +1 -0
  427. package/dist/martyrs/src/modules/music/store/search.js +109 -0
  428. package/dist/martyrs/src/modules/music/store/search.js.map +1 -0
  429. package/dist/martyrs/src/modules/music/store/tracks.cjs +184 -0
  430. package/dist/martyrs/src/modules/music/store/tracks.cjs.map +1 -0
  431. package/dist/martyrs/src/modules/music/store/tracks.js +184 -0
  432. package/dist/martyrs/src/modules/music/store/tracks.js.map +1 -0
  433. package/dist/martyrs/src/modules/notifications/components/elements/NotificationBadge.vue.cjs +1 -1
  434. package/dist/martyrs/src/modules/notifications/components/elements/NotificationBadge.vue.js +1 -1
  435. package/dist/martyrs/src/modules/orders/components/pages/OrderBackoffice.vue.cjs +2 -2
  436. package/dist/martyrs/src/modules/orders/components/pages/OrderBackoffice.vue.js +2 -2
  437. package/dist/martyrs/src/modules/orders/components/pages/OrderCreate.vue.cjs +1 -1
  438. package/dist/martyrs/src/modules/orders/components/pages/OrderCreate.vue.js +1 -1
  439. package/dist/martyrs/src/modules/orders/components/pages/OrderCreateBackoffice.vue.cjs +3 -2
  440. package/dist/martyrs/src/modules/orders/components/pages/OrderCreateBackoffice.vue.cjs.map +1 -1
  441. package/dist/martyrs/src/modules/orders/components/pages/OrderCreateBackoffice.vue.js +3 -2
  442. package/dist/martyrs/src/modules/orders/components/pages/OrderCreateBackoffice.vue.js.map +1 -1
  443. package/dist/martyrs/src/modules/orders/components/sections/FormAddCustomer.vue.cjs +2 -1
  444. package/dist/martyrs/src/modules/orders/components/sections/FormAddCustomer.vue.cjs.map +1 -1
  445. package/dist/martyrs/src/modules/orders/components/sections/FormAddCustomer.vue.js +2 -1
  446. package/dist/martyrs/src/modules/orders/components/sections/FormAddCustomer.vue.js.map +1 -1
  447. package/dist/martyrs/src/modules/orders/components/sections/FormCustomerDetails.vue.cjs +1 -1
  448. package/dist/martyrs/src/modules/orders/components/sections/FormCustomerDetails.vue.js +5 -5
  449. package/dist/martyrs/src/modules/orders/components/sections/FormDelivery.vue.cjs +2 -2
  450. package/dist/martyrs/src/modules/orders/components/sections/FormDelivery.vue.js +3 -3
  451. package/dist/martyrs/src/modules/organizations/components/blocks/CardOrganization.vue.cjs +1 -1
  452. package/dist/martyrs/src/modules/organizations/components/blocks/CardOrganization.vue.js +1 -1
  453. package/dist/martyrs/src/modules/organizations/components/blocks/Socials.vue.js +16 -16
  454. package/dist/martyrs/src/modules/organizations/components/elements/ButtonToggleMembership.vue.cjs +1 -1
  455. package/dist/martyrs/src/modules/organizations/components/elements/ButtonToggleMembership.vue.js +1 -1
  456. package/dist/martyrs/src/modules/organizations/components/pages/DepartmentEdit.vue.cjs +3 -3
  457. package/dist/martyrs/src/modules/organizations/components/pages/DepartmentEdit.vue.js +16 -16
  458. package/dist/martyrs/src/modules/organizations/components/pages/Members.vue.cjs +2 -2
  459. package/dist/martyrs/src/modules/organizations/components/pages/Members.vue.js +2 -2
  460. package/dist/martyrs/src/modules/organizations/components/pages/Organization.vue.cjs +1 -1
  461. package/dist/martyrs/src/modules/organizations/components/pages/Organization.vue.js +1 -1
  462. package/dist/martyrs/src/modules/organizations/components/pages/OrganizationBackoffice.vue.cjs +1 -1
  463. package/dist/martyrs/src/modules/organizations/components/pages/OrganizationBackoffice.vue.js +1 -1
  464. package/dist/martyrs/src/modules/organizations/components/pages/OrganizationEdit.vue.cjs +3 -3
  465. package/dist/martyrs/src/modules/organizations/components/pages/OrganizationEdit.vue.js +17 -17
  466. package/dist/martyrs/src/modules/organizations/components/sections/DetailsTabSection.vue.cjs +1 -1
  467. package/dist/martyrs/src/modules/organizations/components/sections/DetailsTabSection.vue.js +1 -1
  468. package/dist/martyrs/src/modules/organizations/components/sections/Documents.vue.cjs +3 -3
  469. package/dist/martyrs/src/modules/organizations/components/sections/Documents.vue.js +4 -4
  470. package/dist/martyrs/src/modules/organizations/components/sections/MembersAdd.vue.cjs +2 -2
  471. package/dist/martyrs/src/modules/organizations/components/sections/MembersAdd.vue.js +8 -8
  472. package/dist/martyrs/src/modules/organizations/components/sections/Organizations.vue.cjs +2 -1
  473. package/dist/martyrs/src/modules/organizations/components/sections/Organizations.vue.cjs.map +1 -1
  474. package/dist/martyrs/src/modules/organizations/components/sections/Organizations.vue.js +2 -1
  475. package/dist/martyrs/src/modules/organizations/components/sections/Organizations.vue.js.map +1 -1
  476. package/dist/martyrs/src/modules/organizations/router/organizations.cjs +1 -1
  477. package/dist/martyrs/src/modules/organizations/router/organizations.js +1 -1
  478. package/dist/martyrs/src/modules/pages/views/components/blocks/CardPage.vue.cjs +2 -1
  479. package/dist/martyrs/src/modules/pages/views/components/blocks/CardPage.vue.cjs.map +1 -1
  480. package/dist/martyrs/src/modules/pages/views/components/blocks/CardPage.vue.js +2 -1
  481. package/dist/martyrs/src/modules/pages/views/components/blocks/CardPage.vue.js.map +1 -1
  482. package/dist/martyrs/src/modules/pages/views/components/pages/PageEdit.vue.cjs +2 -1
  483. package/dist/martyrs/src/modules/pages/views/components/pages/PageEdit.vue.cjs.map +1 -1
  484. package/dist/martyrs/src/modules/pages/views/components/pages/PageEdit.vue.js +2 -1
  485. package/dist/martyrs/src/modules/pages/views/components/pages/PageEdit.vue.js.map +1 -1
  486. package/dist/martyrs/src/modules/pages/views/components/partials/SidebarPages.vue.cjs +2 -2
  487. package/dist/martyrs/src/modules/pages/views/components/partials/SidebarPages.vue.js +2 -2
  488. package/dist/martyrs/src/modules/products/components/blocks/ProductDiscounts.vue.cjs +1 -1
  489. package/dist/martyrs/src/modules/products/components/blocks/ProductDiscounts.vue.js +1 -1
  490. package/dist/martyrs/src/modules/products/components/blocks/ProductImages.vue.cjs +1 -1
  491. package/dist/martyrs/src/modules/products/components/blocks/ProductImages.vue.js +1 -1
  492. package/dist/martyrs/src/modules/products/components/forms/ReorderSettingsForm.vue.cjs +1 -1
  493. package/dist/martyrs/src/modules/products/components/forms/ReorderSettingsForm.vue.js +8 -8
  494. package/dist/martyrs/src/modules/products/components/forms/StockAuditForm.vue.cjs +1 -1
  495. package/dist/martyrs/src/modules/products/components/forms/StockAuditForm.vue.js +12 -12
  496. package/dist/martyrs/src/modules/products/components/pages/Categories.vue.cjs +1 -1
  497. package/dist/martyrs/src/modules/products/components/pages/Categories.vue.js +1 -1
  498. package/dist/martyrs/src/modules/products/components/pages/CategoryEdit.vue.cjs +3 -3
  499. package/dist/martyrs/src/modules/products/components/pages/CategoryEdit.vue.js +13 -13
  500. package/dist/martyrs/src/modules/products/components/pages/LeftoverEdit.vue.cjs +3 -3
  501. package/dist/martyrs/src/modules/products/components/pages/LeftoverEdit.vue.js +11 -11
  502. package/dist/martyrs/src/modules/products/components/pages/Leftovers.vue.cjs +2 -2
  503. package/dist/martyrs/src/modules/products/components/pages/Leftovers.vue.js +1 -1
  504. package/dist/martyrs/src/modules/products/components/pages/Product.vue.cjs +2 -2
  505. package/dist/martyrs/src/modules/products/components/pages/Product.vue.cjs.map +1 -1
  506. package/dist/martyrs/src/modules/products/components/pages/Product.vue.js +2 -2
  507. package/dist/martyrs/src/modules/products/components/pages/Product.vue.js.map +1 -1
  508. package/dist/martyrs/src/modules/products/components/pages/ProductEdit.vue.cjs +2 -2
  509. package/dist/martyrs/src/modules/products/components/pages/ProductEdit.vue.js +18 -18
  510. package/dist/martyrs/src/modules/products/components/sections/EditAttributes.vue.cjs +3 -3
  511. package/dist/martyrs/src/modules/products/components/sections/EditAttributes.vue.js +7 -7
  512. package/dist/martyrs/src/modules/products/components/sections/EditDiscounts.vue.cjs +3 -3
  513. package/dist/martyrs/src/modules/products/components/sections/EditDiscounts.vue.js +13 -13
  514. package/dist/martyrs/src/modules/products/components/sections/EditIngredients.vue.cjs +1 -1
  515. package/dist/martyrs/src/modules/products/components/sections/EditIngredients.vue.js +1 -1
  516. package/dist/martyrs/src/modules/products/components/sections/EditRecommended.vue.cjs +1 -1
  517. package/dist/martyrs/src/modules/products/components/sections/EditRecommended.vue.js +1 -1
  518. package/dist/martyrs/src/modules/products/components/sections/EditVariants.vue.cjs +3 -3
  519. package/dist/martyrs/src/modules/products/components/sections/EditVariants.vue.js +17 -17
  520. package/dist/martyrs/src/modules/products/components/sections/ProductConfigurator.vue.cjs +1 -1
  521. package/dist/martyrs/src/modules/products/components/sections/ProductConfigurator.vue.js +1 -1
  522. package/dist/martyrs/src/modules/products/components/sections/ProductsRecommended.vue.cjs +1 -1
  523. package/dist/martyrs/src/modules/products/components/sections/ProductsRecommended.vue.js +1 -1
  524. package/dist/martyrs/src/modules/products/components/sections/SectionProduct.vue.cjs +1 -1
  525. package/dist/martyrs/src/modules/products/components/sections/SectionProduct.vue.js +1 -1
  526. package/dist/martyrs/src/modules/rents/views/components/pages/RentsEdit.vue.cjs +2 -2
  527. package/dist/martyrs/src/modules/rents/views/components/pages/RentsEdit.vue.js +5 -5
  528. package/dist/martyrs/src/modules/reports/components/sections/FormReport.vue.cjs +2 -2
  529. package/dist/martyrs/src/modules/reports/components/sections/FormReport.vue.js +2 -2
  530. package/dist/martyrs/src/modules/spots/components/blocks/CardSpot.vue.cjs +1 -1
  531. package/dist/martyrs/src/modules/spots/components/blocks/CardSpot.vue.js +1 -1
  532. package/dist/martyrs/src/modules/spots/components/blocks/SpotMemberModify.vue.cjs +1 -0
  533. package/dist/martyrs/src/modules/spots/components/blocks/SpotMemberModify.vue.cjs.map +1 -1
  534. package/dist/martyrs/src/modules/spots/components/blocks/SpotMemberModify.vue.js +1 -0
  535. package/dist/martyrs/src/modules/spots/components/blocks/SpotMemberModify.vue.js.map +1 -1
  536. package/dist/martyrs/src/modules/spots/components/layouts/Spots.vue.cjs +1 -0
  537. package/dist/martyrs/src/modules/spots/components/layouts/Spots.vue.cjs.map +1 -1
  538. package/dist/martyrs/src/modules/spots/components/layouts/Spots.vue.js +1 -0
  539. package/dist/martyrs/src/modules/spots/components/layouts/Spots.vue.js.map +1 -1
  540. package/dist/martyrs/src/modules/spots/components/pages/Map.vue.cjs +1 -1
  541. package/dist/martyrs/src/modules/spots/components/pages/Map.vue.js +1 -1
  542. package/dist/martyrs/src/modules/spots/components/pages/SpotEdit.vue.cjs +3 -3
  543. package/dist/martyrs/src/modules/spots/components/pages/SpotEdit.vue.js +14 -14
  544. package/dist/martyrs/src/modules/spots/components/sections/WorktimeEdit.vue.cjs +3 -3
  545. package/dist/martyrs/src/modules/spots/components/sections/WorktimeEdit.vue.js +9 -9
  546. package/dist/martyrs/src/modules/wallet/views/components/blocks/CardDeposit.vue.cjs +1 -1
  547. package/dist/martyrs/src/modules/wallet/views/components/blocks/CardDeposit.vue.js +2 -2
  548. package/dist/martyrs/src/modules/wallet/views/components/blocks/CryptoDeposit.vue.cjs +1 -1
  549. package/dist/martyrs/src/modules/wallet/views/components/blocks/CryptoDeposit.vue.js +2 -2
  550. package/dist/martyrs/src/modules/wallet/views/components/pages/Wallet.vue.cjs +3 -3
  551. package/dist/martyrs/src/modules/wallet/views/components/pages/Wallet.vue.js +3 -3
  552. package/dist/martyrs.cjs.js +1 -1
  553. package/dist/martyrs.css +1 -1
  554. package/dist/martyrs.es.js +38 -36
  555. package/dist/music.server.cjs +2021 -0
  556. package/dist/music.server.js +2021 -0
  557. package/dist/node_modules/.pnpm/qrcode@1.5.4/node_modules/qrcode/lib/core/utils.cjs +1 -1
  558. package/dist/node_modules/.pnpm/qrcode@1.5.4/node_modules/qrcode/lib/core/utils.js +1 -1
  559. package/dist/node_modules/.pnpm/qrcode@1.5.4/node_modules/qrcode/lib/renderer/utils.cjs +1 -1
  560. package/dist/node_modules/.pnpm/qrcode@1.5.4/node_modules/qrcode/lib/renderer/utils.js +1 -1
  561. package/dist/orders.server.cjs +1 -1
  562. package/dist/orders.server.js +1 -1
  563. package/dist/organizations.server.cjs +1 -1
  564. package/dist/organizations.server.js +1 -1
  565. package/dist/products.server.cjs +3 -1093
  566. package/dist/products.server.js +2 -1092
  567. package/dist/rents.server.cjs +1 -1
  568. package/dist/rents.server.js +1 -1
  569. package/dist/socials.schema-BOZV82Mp.js +25 -0
  570. package/dist/socials.schema-CtpSF9dE.cjs +24 -0
  571. package/dist/style.css +230 -46
  572. package/dist/wallet.server.cjs +1 -1
  573. package/dist/wallet.server.js +1 -1
  574. package/package.json +1 -1
  575. package/src/.martyrs/filemap.json +2 -2
  576. package/src/components/Feed/Feed.vue +1 -1
  577. package/src/components/Field/Field.vue +13 -8
  578. package/src/components/FieldBig/FieldBig.vue +3 -5
  579. package/src/components/FieldPhone/FieldPhone.vue +1 -1
  580. package/src/components/Media/Media.vue +1 -1
  581. package/src/components/Select/Select.vue +1 -1
  582. package/src/components/Status/Snack.vue +83 -0
  583. package/src/components/index.js +2 -0
  584. package/src/main.js +6 -0
  585. package/src/modules/auth/controllers/middlewares/authJwt.js +59 -6
  586. package/src/modules/events/components/pages/EditEvent.vue +1 -1
  587. package/src/modules/globals/views/classes/globals.store.js +31 -66
  588. package/src/modules/globals/views/components/blocks/PopupDateSelector.vue +1 -1
  589. package/src/modules/globals/views/components/partials/FooterAlt.vue +363 -0
  590. package/src/modules/globals/views/store/globals.js +42 -0
  591. package/src/modules/globals/views/utils/axios-instance.js +15 -1
  592. package/src/modules/globals/views/utils/query-serializer.js +182 -0
  593. package/src/modules/icons/components/IconSearchPopup.vue +254 -0
  594. package/src/modules/icons/entities/IconAddress.vue +17 -0
  595. package/src/modules/icons/entities/IconDate.vue +3 -3
  596. package/src/modules/icons/entities/IconEmail.vue +14 -0
  597. package/src/modules/icons/entities/IconMusic.vue +3 -3
  598. package/src/modules/icons/entities/IconPhone.vue +14 -0
  599. package/src/modules/icons/icons.client.js +85 -31
  600. package/src/modules/icons/icons.server.js +292 -0
  601. package/src/modules/icons/navigation/IconCross.vue +4 -16
  602. package/src/modules/icons/navigation/IconPause.vue +9 -24
  603. package/src/modules/icons/navigation/IconRefresh.vue +9 -24
  604. package/src/modules/icons/pages/IconsPage.vue +78 -2
  605. package/src/modules/icons/routes/icons.routes.js +81 -0
  606. package/src/modules/icons/socials/dribbble.vue +11 -2
  607. package/src/modules/icons/socials/facebook.vue +11 -2
  608. package/src/modules/icons/socials/instagram.vue +11 -4
  609. package/src/modules/icons/socials/line.vue +11 -2
  610. package/src/modules/icons/socials/linkedin.vue +11 -2
  611. package/src/modules/icons/socials/reddit.vue +10 -1
  612. package/src/modules/icons/socials/telegram.vue +11 -2
  613. package/src/modules/icons/socials/twitter.vue +11 -2
  614. package/src/modules/icons/socials/vk.vue +11 -2
  615. package/src/modules/icons/socials/whatsapp.vue +12 -0
  616. package/src/modules/icons/socials/youtube.vue +11 -2
  617. package/src/modules/music/.claude/settings.local.json +8 -0
  618. package/src/modules/music/CLAUDE.md +312 -0
  619. package/src/modules/music/components/SidebarMusic.vue +8 -8
  620. package/src/modules/music/components/cards/AlbumCard.vue +2 -2
  621. package/src/modules/music/components/cards/ArtistCard.vue +2 -2
  622. package/src/modules/music/components/cards/PlaylistCard.vue +2 -2
  623. package/src/modules/music/components/cards/TrackCard.vue +1 -1
  624. package/src/modules/music/components/cards/TrackListCard.vue +135 -0
  625. package/src/modules/music/components/forms/AlbumForm.vue +463 -0
  626. package/src/modules/music/components/{pages → forms}/ArtistForm.vue +127 -96
  627. package/src/modules/music/components/forms/PlaylistForm.vue +10 -10
  628. package/src/modules/music/components/forms/SearchForm.vue +1 -1
  629. package/src/modules/music/components/forms/TrackForm.vue +577 -0
  630. package/src/modules/music/components/layouts/MusicLayout.vue +35 -41
  631. package/src/modules/music/components/pages/{AlbumDetail.vue → Album.vue} +42 -20
  632. package/src/modules/music/components/pages/AlbumCreate.vue +7 -0
  633. package/src/modules/music/components/pages/AlbumEdit.vue +14 -0
  634. package/src/modules/music/components/pages/{ArtistDetail.vue → Artist.vue} +9 -9
  635. package/src/modules/music/components/pages/ArtistCreate.vue +7 -0
  636. package/src/modules/music/components/pages/ArtistEdit.vue +14 -0
  637. package/src/modules/music/components/pages/MusicHome.vue +86 -67
  638. package/src/modules/music/components/pages/MusicLibrary.vue +136 -105
  639. package/src/modules/music/components/pages/{PlaylistDetail.vue → Playlist.vue} +56 -34
  640. package/src/modules/music/components/pages/PlaylistCreate.vue +7 -0
  641. package/src/modules/music/components/pages/PlaylistEdit.vue +14 -0
  642. package/src/modules/music/components/pages/SearchResults.vue +49 -27
  643. package/src/modules/music/components/pages/{TrackDetail.vue → Track.vue} +36 -14
  644. package/src/modules/music/components/pages/TrackCreate.vue +23 -0
  645. package/src/modules/music/components/pages/TrackEdit.vue +14 -0
  646. package/src/modules/music/components/player/MusicPlayer.vue +2 -2
  647. package/src/modules/music/middlewares/albums.verifier.js +234 -0
  648. package/src/modules/music/middlewares/artists.verifier.js +213 -0
  649. package/src/modules/music/middlewares/genres.verifier.js +148 -0
  650. package/src/modules/music/middlewares/playlists.verifier.js +219 -0
  651. package/src/modules/music/middlewares/tracks.verifier.js +263 -0
  652. package/src/modules/music/music.client.js +31 -33
  653. package/src/modules/music/music.server.js +33 -26
  654. package/src/modules/music/router/albums.js +31 -0
  655. package/src/modules/music/router/artists.js +31 -0
  656. package/src/modules/music/router/music.js +14 -65
  657. package/src/modules/music/router/playlists.js +31 -0
  658. package/src/modules/music/router/tracks.js +31 -0
  659. package/src/modules/music/routes/albums.routes.js +126 -0
  660. package/src/modules/music/routes/artists.routes.js +171 -0
  661. package/src/modules/music/routes/genres.routes.js +118 -0
  662. package/src/modules/music/routes/playlists.routes.js +239 -0
  663. package/src/modules/music/routes/tracks.routes.js +149 -0
  664. package/src/modules/music/store/artists.js +17 -7
  665. package/src/modules/music/store/genres.js +150 -0
  666. package/src/modules/music/store/playlists.js +19 -6
  667. package/src/modules/music/store/tracks.js +9 -2
  668. package/src/modules/products/components/pages/Product.vue +1 -1
  669. package/dist/Media-ByPHBvAU.cjs +0 -1
  670. package/dist/main-137vO86w.cjs +0 -11
  671. package/dist/martyrs/src/components/Button/Button.vue2.cjs.map +0 -1
  672. package/dist/martyrs/src/components/Chips/Chips.vue2.cjs.map +0 -1
  673. package/dist/martyrs/src/components/Chips/Chips.vue2.js.map +0 -1
  674. package/dist/martyrs/src/components/DatePicker/Calendar.vue.cjs.map +0 -1
  675. package/dist/martyrs/src/components/DatePicker/Calendar.vue.js.map +0 -1
  676. package/dist/martyrs/src/components/Field/Field.vue.cjs.map +0 -1
  677. package/dist/martyrs/src/components/Field/Field.vue.js.map +0 -1
  678. package/dist/martyrs/src/components/Menu/Menu.vue2.cjs.map +0 -1
  679. package/dist/martyrs/src/components/Menu/Menu.vue2.js.map +0 -1
  680. package/dist/martyrs/src/components/Popup/Popup.vue2.cjs.map +0 -1
  681. package/src/modules/music/components/forms/UploadForm.vue +0 -313
  682. package/src/modules/music/components/lists/AlbumList.vue +0 -25
  683. package/src/modules/music/components/lists/ArtistList.vue +0 -280
  684. package/src/modules/music/components/lists/PlaylistList.vue +0 -25
  685. package/src/modules/music/components/lists/TrackList.vue +0 -175
  686. package/src/modules/music/components/pages/ArtistManager.vue +0 -277
  687. package/src/modules/music/components/pages/MusicUpload.vue +0 -44
  688. package/src/modules/music/controllers/album.controller.js +0 -82
  689. package/src/modules/music/controllers/artist.controller.js +0 -99
  690. package/src/modules/music/controllers/genre.controller.js +0 -63
  691. package/src/modules/music/controllers/music.controller.js +0 -145
  692. package/src/modules/music/controllers/playlist.controller.js +0 -146
  693. package/src/modules/music/routes/album.routes.js +0 -28
  694. package/src/modules/music/routes/artist.routes.js +0 -30
  695. package/src/modules/music/routes/genre.routes.js +0 -28
  696. package/src/modules/music/routes/music.routes.js +0 -106
  697. package/src/modules/music/routes/playlist.routes.js +0 -47
  698. /package/src/components/{DatePicker → Calendar}/Calendar.vue +0 -0
@@ -0,0 +1,182 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const globals_store = require("../../globals/views/classes/globals.store.cjs");
4
+ const vue = require("vue");
5
+ const playlistStore = new globals_store.default(`${process.env.API_URL}/api/playlists`);
6
+ const state = vue.reactive({
7
+ playlists: [],
8
+ featuredPlaylists: [],
9
+ userPlaylists: [],
10
+ currentPlaylist: null,
11
+ currentPlaylistTracks: [],
12
+ isLoading: false,
13
+ loadingFeatured: false
14
+ });
15
+ const actions = {
16
+ async fetchPlaylists(options = {}) {
17
+ state.isLoading = true;
18
+ try {
19
+ const playlists = await playlistStore.read(options);
20
+ state.playlists = playlists;
21
+ return playlists;
22
+ } catch (error) {
23
+ console.error("Error fetching playlists:", error);
24
+ return [];
25
+ } finally {
26
+ state.isLoading = false;
27
+ }
28
+ },
29
+ async fetchFeaturedPlaylists(options = {}) {
30
+ state.loadingFeatured = true;
31
+ try {
32
+ const queryOptions = {
33
+ limit: options.limit || 10,
34
+ isPublic: true
35
+ };
36
+ if (options.skip) queryOptions.skip = options.skip;
37
+ if (options.search) queryOptions.search = options.search;
38
+ if (options.sortParam) queryOptions.sortParam = options.sortParam;
39
+ if (options.sortOrder) queryOptions.sortOrder = options.sortOrder;
40
+ if (options.featured) {
41
+ queryOptions.status = "featured";
42
+ queryOptions.sortParam = queryOptions.sortParam || "followers";
43
+ queryOptions.sortOrder = queryOptions.sortOrder || "desc";
44
+ }
45
+ const playlists = await playlistStore.read(queryOptions);
46
+ state.featuredPlaylists = playlists;
47
+ return playlists;
48
+ } catch (error) {
49
+ console.error("Error fetching featured playlists:", error);
50
+ return [];
51
+ } finally {
52
+ state.loadingFeatured = false;
53
+ }
54
+ },
55
+ async fetchPlaylistByUrl(url) {
56
+ var _a;
57
+ try {
58
+ const response = await fetch(`${process.env.API_URL}/api/playlists/url/${url}`);
59
+ const playlist = await response.json();
60
+ state.currentPlaylist = playlist;
61
+ state.currentPlaylistTracks = ((_a = playlist.tracks) == null ? void 0 : _a.map((item) => item.track)) || [];
62
+ return playlist;
63
+ } catch (error) {
64
+ console.error("Error fetching playlist by URL:", error);
65
+ return null;
66
+ }
67
+ },
68
+ async createPlaylist(playlistData) {
69
+ try {
70
+ const createdPlaylist = await playlistStore.create(playlistData);
71
+ state.playlists.unshift(createdPlaylist);
72
+ state.userPlaylists.unshift(createdPlaylist);
73
+ return createdPlaylist;
74
+ } catch (error) {
75
+ console.error("Error creating playlist:", error);
76
+ throw error;
77
+ }
78
+ },
79
+ async updatePlaylist(playlistData) {
80
+ try {
81
+ const updatedPlaylist = await playlistStore.update(playlistData);
82
+ const index = state.playlists.findIndex((p) => p._id === updatedPlaylist._id);
83
+ if (index !== -1) {
84
+ state.playlists[index] = updatedPlaylist;
85
+ }
86
+ const userIndex = state.userPlaylists.findIndex((p) => p._id === updatedPlaylist._id);
87
+ if (userIndex !== -1) {
88
+ state.userPlaylists[userIndex] = updatedPlaylist;
89
+ }
90
+ if (state.currentPlaylist && state.currentPlaylist._id === updatedPlaylist._id) {
91
+ state.currentPlaylist = updatedPlaylist;
92
+ }
93
+ return updatedPlaylist;
94
+ } catch (error) {
95
+ console.error("Error updating playlist:", error);
96
+ throw error;
97
+ }
98
+ },
99
+ async deletePlaylist(playlistId) {
100
+ try {
101
+ await playlistStore.delete({ _id: playlistId });
102
+ state.playlists = state.playlists.filter((p) => p._id !== playlistId);
103
+ state.userPlaylists = state.userPlaylists.filter((p) => p._id !== playlistId);
104
+ if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {
105
+ state.currentPlaylist = null;
106
+ state.currentPlaylistTracks = [];
107
+ }
108
+ return true;
109
+ } catch (error) {
110
+ console.error("Error deleting playlist:", error);
111
+ throw error;
112
+ }
113
+ },
114
+ async fetchUserPlaylists(userId) {
115
+ try {
116
+ const response = await fetch(`${process.env.API_URL}/api/playlists/user/${userId || ""}`);
117
+ const playlists = await response.json();
118
+ state.userPlaylists = playlists;
119
+ return playlists;
120
+ } catch (error) {
121
+ console.error("Error fetching user playlists:", error);
122
+ return [];
123
+ }
124
+ },
125
+ async addTrackToPlaylist(playlistId, trackId) {
126
+ var _a;
127
+ try {
128
+ const response = await fetch(`${process.env.API_URL}/api/playlists/${playlistId}/tracks/${trackId}`, {
129
+ method: "POST",
130
+ headers: {
131
+ "Content-Type": "application/json"
132
+ }
133
+ });
134
+ const updatedPlaylist = await response.json();
135
+ if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {
136
+ state.currentPlaylist = updatedPlaylist;
137
+ const track = (_a = updatedPlaylist.tracks.find((item) => item.track._id === trackId)) == null ? void 0 : _a.track;
138
+ if (track && !state.currentPlaylistTracks.some((t) => t._id === trackId)) {
139
+ state.currentPlaylistTracks.push(track);
140
+ }
141
+ }
142
+ return updatedPlaylist;
143
+ } catch (error) {
144
+ console.error("Error adding track to playlist:", error);
145
+ throw error;
146
+ }
147
+ },
148
+ async removeTrackFromPlaylist(playlistId, trackId) {
149
+ try {
150
+ const response = await fetch(`${process.env.API_URL}/api/playlists/${playlistId}/tracks/${trackId}`, {
151
+ method: "DELETE"
152
+ });
153
+ const updatedPlaylist = await response.json();
154
+ if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {
155
+ state.currentPlaylist = updatedPlaylist;
156
+ state.currentPlaylistTracks = state.currentPlaylistTracks.filter((track) => track._id !== trackId);
157
+ }
158
+ return updatedPlaylist;
159
+ } catch (error) {
160
+ console.error("Error removing track from playlist:", error);
161
+ throw error;
162
+ }
163
+ },
164
+ async addCollaborator(playlistId, userId) {
165
+ try {
166
+ const response = await fetch(`${process.env.API_URL}/api/playlists/${playlistId}/collaborators/${userId}`, {
167
+ method: "POST"
168
+ });
169
+ const updatedPlaylist = await response.json();
170
+ if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {
171
+ state.currentPlaylist = updatedPlaylist;
172
+ }
173
+ return updatedPlaylist;
174
+ } catch (error) {
175
+ console.error("Error adding collaborator to playlist:", error);
176
+ throw error;
177
+ }
178
+ }
179
+ };
180
+ exports.actions = actions;
181
+ exports.state = state;
182
+ //# sourceMappingURL=playlists.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"playlists.cjs","sources":["../../../../../../src/modules/music/store/playlists.js"],"sourcesContent":["// store/playlists.js\nimport Store from '@martyrs/src/modules/globals/views/classes/globals.store.js';\nimport { reactive } from 'vue';\n\n// Create store instance\nconst playlistStore = new Store(`${process.env.API_URL}/api/playlists`);\n\n// State\nexport const state = reactive({\n playlists: [],\n featuredPlaylists: [],\n userPlaylists: [],\n currentPlaylist: null,\n currentPlaylistTracks: [],\n isLoading: false,\n loadingFeatured: false,\n});\n\n// Actions\nexport const actions = {\n async fetchPlaylists(options = {}) {\n state.isLoading = true;\n try {\n const playlists = await playlistStore.read(options);\n state.playlists = playlists;\n return playlists;\n } catch (error) {\n console.error('Error fetching playlists:', error);\n return [];\n } finally {\n state.isLoading = false;\n }\n },\n\n async fetchFeaturedPlaylists(options = {}) {\n state.loadingFeatured = true;\n try {\n // Обрабатываем options от Feed компонента\n const queryOptions = {\n limit: options.limit || 10,\n isPublic: true,\n };\n \n // Добавляем дополнительные параметры если есть\n if (options.skip) queryOptions.skip = options.skip;\n if (options.search) queryOptions.search = options.search;\n if (options.sortParam) queryOptions.sortParam = options.sortParam;\n if (options.sortOrder) queryOptions.sortOrder = options.sortOrder;\n \n // Если указан featured=true, добавляем соответствующий фильтр\n if (options.featured) {\n queryOptions.status = 'featured';\n // Или можно использовать sortParam для featured плейлистов\n queryOptions.sortParam = queryOptions.sortParam || 'followers';\n queryOptions.sortOrder = queryOptions.sortOrder || 'desc';\n }\n\n const playlists = await playlistStore.read(queryOptions);\n state.featuredPlaylists = playlists;\n return playlists;\n } catch (error) {\n console.error('Error fetching featured playlists:', error);\n return [];\n } finally {\n state.loadingFeatured = false;\n }\n },\n\n async fetchPlaylistByUrl(url) {\n try {\n const response = await fetch(`${process.env.API_URL}/api/playlists/url/${url}`);\n const playlist = await response.json();\n state.currentPlaylist = playlist;\n\n // Extract tracks from the playlist\n state.currentPlaylistTracks = playlist.tracks?.map(item => item.track) || [];\n\n return playlist;\n } catch (error) {\n console.error('Error fetching playlist by URL:', error);\n return null;\n }\n },\n\n async createPlaylist(playlistData) {\n try {\n const createdPlaylist = await playlistStore.create(playlistData);\n // Update local state\n state.playlists.unshift(createdPlaylist);\n state.userPlaylists.unshift(createdPlaylist);\n return createdPlaylist;\n } catch (error) {\n console.error('Error creating playlist:', error);\n throw error;\n }\n },\n\n async updatePlaylist(playlistData) {\n try {\n const updatedPlaylist = await playlistStore.update(playlistData);\n\n // Update local state\n const index = state.playlists.findIndex(p => p._id === updatedPlaylist._id);\n if (index !== -1) {\n state.playlists[index] = updatedPlaylist;\n }\n\n const userIndex = state.userPlaylists.findIndex(p => p._id === updatedPlaylist._id);\n if (userIndex !== -1) {\n state.userPlaylists[userIndex] = updatedPlaylist;\n }\n\n if (state.currentPlaylist && state.currentPlaylist._id === updatedPlaylist._id) {\n state.currentPlaylist = updatedPlaylist;\n }\n\n return updatedPlaylist;\n } catch (error) {\n console.error('Error updating playlist:', error);\n throw error;\n }\n },\n\n async deletePlaylist(playlistId) {\n try {\n await playlistStore.delete({ _id: playlistId });\n\n // Update local state\n state.playlists = state.playlists.filter(p => p._id !== playlistId);\n state.userPlaylists = state.userPlaylists.filter(p => p._id !== playlistId);\n\n if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {\n state.currentPlaylist = null;\n state.currentPlaylistTracks = [];\n }\n\n return true;\n } catch (error) {\n console.error('Error deleting playlist:', error);\n throw error;\n }\n },\n\n async fetchUserPlaylists(userId) {\n try {\n const response = await fetch(`${process.env.API_URL}/api/playlists/user/${userId || ''}`);\n const playlists = await response.json();\n state.userPlaylists = playlists;\n return playlists;\n } catch (error) {\n console.error('Error fetching user playlists:', error);\n return [];\n }\n },\n\n async addTrackToPlaylist(playlistId, trackId) {\n try {\n const response = await fetch(`${process.env.API_URL}/api/playlists/${playlistId}/tracks/${trackId}`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n });\n\n const updatedPlaylist = await response.json();\n\n // Update local state\n if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {\n state.currentPlaylist = updatedPlaylist;\n // Update tracks list\n const track = updatedPlaylist.tracks.find(item => item.track._id === trackId)?.track;\n if (track && !state.currentPlaylistTracks.some(t => t._id === trackId)) {\n state.currentPlaylistTracks.push(track);\n }\n }\n\n return updatedPlaylist;\n } catch (error) {\n console.error('Error adding track to playlist:', error);\n throw error;\n }\n },\n\n async removeTrackFromPlaylist(playlistId, trackId) {\n try {\n const response = await fetch(`${process.env.API_URL}/api/playlists/${playlistId}/tracks/${trackId}`, {\n method: 'DELETE',\n });\n\n const updatedPlaylist = await response.json();\n\n // Update local state\n if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {\n state.currentPlaylist = updatedPlaylist;\n state.currentPlaylistTracks = state.currentPlaylistTracks.filter(track => track._id !== trackId);\n }\n\n return updatedPlaylist;\n } catch (error) {\n console.error('Error removing track from playlist:', error);\n throw error;\n }\n },\n\n async addCollaborator(playlistId, userId) {\n try {\n const response = await fetch(`${process.env.API_URL}/api/playlists/${playlistId}/collaborators/${userId}`, {\n method: 'POST',\n });\n\n const updatedPlaylist = await response.json();\n\n // Update local state\n if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {\n state.currentPlaylist = updatedPlaylist;\n }\n\n return updatedPlaylist;\n } catch (error) {\n console.error('Error adding collaborator to playlist:', error);\n throw error;\n }\n },\n};\n"],"names":["Store","reactive"],"mappings":"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"}
@@ -0,0 +1,182 @@
1
+ import Store from "../../globals/views/classes/globals.store.js";
2
+ import { reactive } from "vue";
3
+ const playlistStore = new Store(`${process.env.API_URL}/api/playlists`);
4
+ const state = reactive({
5
+ playlists: [],
6
+ featuredPlaylists: [],
7
+ userPlaylists: [],
8
+ currentPlaylist: null,
9
+ currentPlaylistTracks: [],
10
+ isLoading: false,
11
+ loadingFeatured: false
12
+ });
13
+ const actions = {
14
+ async fetchPlaylists(options = {}) {
15
+ state.isLoading = true;
16
+ try {
17
+ const playlists = await playlistStore.read(options);
18
+ state.playlists = playlists;
19
+ return playlists;
20
+ } catch (error) {
21
+ console.error("Error fetching playlists:", error);
22
+ return [];
23
+ } finally {
24
+ state.isLoading = false;
25
+ }
26
+ },
27
+ async fetchFeaturedPlaylists(options = {}) {
28
+ state.loadingFeatured = true;
29
+ try {
30
+ const queryOptions = {
31
+ limit: options.limit || 10,
32
+ isPublic: true
33
+ };
34
+ if (options.skip) queryOptions.skip = options.skip;
35
+ if (options.search) queryOptions.search = options.search;
36
+ if (options.sortParam) queryOptions.sortParam = options.sortParam;
37
+ if (options.sortOrder) queryOptions.sortOrder = options.sortOrder;
38
+ if (options.featured) {
39
+ queryOptions.status = "featured";
40
+ queryOptions.sortParam = queryOptions.sortParam || "followers";
41
+ queryOptions.sortOrder = queryOptions.sortOrder || "desc";
42
+ }
43
+ const playlists = await playlistStore.read(queryOptions);
44
+ state.featuredPlaylists = playlists;
45
+ return playlists;
46
+ } catch (error) {
47
+ console.error("Error fetching featured playlists:", error);
48
+ return [];
49
+ } finally {
50
+ state.loadingFeatured = false;
51
+ }
52
+ },
53
+ async fetchPlaylistByUrl(url) {
54
+ var _a;
55
+ try {
56
+ const response = await fetch(`${process.env.API_URL}/api/playlists/url/${url}`);
57
+ const playlist = await response.json();
58
+ state.currentPlaylist = playlist;
59
+ state.currentPlaylistTracks = ((_a = playlist.tracks) == null ? void 0 : _a.map((item) => item.track)) || [];
60
+ return playlist;
61
+ } catch (error) {
62
+ console.error("Error fetching playlist by URL:", error);
63
+ return null;
64
+ }
65
+ },
66
+ async createPlaylist(playlistData) {
67
+ try {
68
+ const createdPlaylist = await playlistStore.create(playlistData);
69
+ state.playlists.unshift(createdPlaylist);
70
+ state.userPlaylists.unshift(createdPlaylist);
71
+ return createdPlaylist;
72
+ } catch (error) {
73
+ console.error("Error creating playlist:", error);
74
+ throw error;
75
+ }
76
+ },
77
+ async updatePlaylist(playlistData) {
78
+ try {
79
+ const updatedPlaylist = await playlistStore.update(playlistData);
80
+ const index = state.playlists.findIndex((p) => p._id === updatedPlaylist._id);
81
+ if (index !== -1) {
82
+ state.playlists[index] = updatedPlaylist;
83
+ }
84
+ const userIndex = state.userPlaylists.findIndex((p) => p._id === updatedPlaylist._id);
85
+ if (userIndex !== -1) {
86
+ state.userPlaylists[userIndex] = updatedPlaylist;
87
+ }
88
+ if (state.currentPlaylist && state.currentPlaylist._id === updatedPlaylist._id) {
89
+ state.currentPlaylist = updatedPlaylist;
90
+ }
91
+ return updatedPlaylist;
92
+ } catch (error) {
93
+ console.error("Error updating playlist:", error);
94
+ throw error;
95
+ }
96
+ },
97
+ async deletePlaylist(playlistId) {
98
+ try {
99
+ await playlistStore.delete({ _id: playlistId });
100
+ state.playlists = state.playlists.filter((p) => p._id !== playlistId);
101
+ state.userPlaylists = state.userPlaylists.filter((p) => p._id !== playlistId);
102
+ if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {
103
+ state.currentPlaylist = null;
104
+ state.currentPlaylistTracks = [];
105
+ }
106
+ return true;
107
+ } catch (error) {
108
+ console.error("Error deleting playlist:", error);
109
+ throw error;
110
+ }
111
+ },
112
+ async fetchUserPlaylists(userId) {
113
+ try {
114
+ const response = await fetch(`${process.env.API_URL}/api/playlists/user/${userId || ""}`);
115
+ const playlists = await response.json();
116
+ state.userPlaylists = playlists;
117
+ return playlists;
118
+ } catch (error) {
119
+ console.error("Error fetching user playlists:", error);
120
+ return [];
121
+ }
122
+ },
123
+ async addTrackToPlaylist(playlistId, trackId) {
124
+ var _a;
125
+ try {
126
+ const response = await fetch(`${process.env.API_URL}/api/playlists/${playlistId}/tracks/${trackId}`, {
127
+ method: "POST",
128
+ headers: {
129
+ "Content-Type": "application/json"
130
+ }
131
+ });
132
+ const updatedPlaylist = await response.json();
133
+ if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {
134
+ state.currentPlaylist = updatedPlaylist;
135
+ const track = (_a = updatedPlaylist.tracks.find((item) => item.track._id === trackId)) == null ? void 0 : _a.track;
136
+ if (track && !state.currentPlaylistTracks.some((t) => t._id === trackId)) {
137
+ state.currentPlaylistTracks.push(track);
138
+ }
139
+ }
140
+ return updatedPlaylist;
141
+ } catch (error) {
142
+ console.error("Error adding track to playlist:", error);
143
+ throw error;
144
+ }
145
+ },
146
+ async removeTrackFromPlaylist(playlistId, trackId) {
147
+ try {
148
+ const response = await fetch(`${process.env.API_URL}/api/playlists/${playlistId}/tracks/${trackId}`, {
149
+ method: "DELETE"
150
+ });
151
+ const updatedPlaylist = await response.json();
152
+ if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {
153
+ state.currentPlaylist = updatedPlaylist;
154
+ state.currentPlaylistTracks = state.currentPlaylistTracks.filter((track) => track._id !== trackId);
155
+ }
156
+ return updatedPlaylist;
157
+ } catch (error) {
158
+ console.error("Error removing track from playlist:", error);
159
+ throw error;
160
+ }
161
+ },
162
+ async addCollaborator(playlistId, userId) {
163
+ try {
164
+ const response = await fetch(`${process.env.API_URL}/api/playlists/${playlistId}/collaborators/${userId}`, {
165
+ method: "POST"
166
+ });
167
+ const updatedPlaylist = await response.json();
168
+ if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {
169
+ state.currentPlaylist = updatedPlaylist;
170
+ }
171
+ return updatedPlaylist;
172
+ } catch (error) {
173
+ console.error("Error adding collaborator to playlist:", error);
174
+ throw error;
175
+ }
176
+ }
177
+ };
178
+ export {
179
+ actions,
180
+ state
181
+ };
182
+ //# sourceMappingURL=playlists.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"playlists.js","sources":["../../../../../../src/modules/music/store/playlists.js"],"sourcesContent":["// store/playlists.js\nimport Store from '@martyrs/src/modules/globals/views/classes/globals.store.js';\nimport { reactive } from 'vue';\n\n// Create store instance\nconst playlistStore = new Store(`${process.env.API_URL}/api/playlists`);\n\n// State\nexport const state = reactive({\n playlists: [],\n featuredPlaylists: [],\n userPlaylists: [],\n currentPlaylist: null,\n currentPlaylistTracks: [],\n isLoading: false,\n loadingFeatured: false,\n});\n\n// Actions\nexport const actions = {\n async fetchPlaylists(options = {}) {\n state.isLoading = true;\n try {\n const playlists = await playlistStore.read(options);\n state.playlists = playlists;\n return playlists;\n } catch (error) {\n console.error('Error fetching playlists:', error);\n return [];\n } finally {\n state.isLoading = false;\n }\n },\n\n async fetchFeaturedPlaylists(options = {}) {\n state.loadingFeatured = true;\n try {\n // Обрабатываем options от Feed компонента\n const queryOptions = {\n limit: options.limit || 10,\n isPublic: true,\n };\n \n // Добавляем дополнительные параметры если есть\n if (options.skip) queryOptions.skip = options.skip;\n if (options.search) queryOptions.search = options.search;\n if (options.sortParam) queryOptions.sortParam = options.sortParam;\n if (options.sortOrder) queryOptions.sortOrder = options.sortOrder;\n \n // Если указан featured=true, добавляем соответствующий фильтр\n if (options.featured) {\n queryOptions.status = 'featured';\n // Или можно использовать sortParam для featured плейлистов\n queryOptions.sortParam = queryOptions.sortParam || 'followers';\n queryOptions.sortOrder = queryOptions.sortOrder || 'desc';\n }\n\n const playlists = await playlistStore.read(queryOptions);\n state.featuredPlaylists = playlists;\n return playlists;\n } catch (error) {\n console.error('Error fetching featured playlists:', error);\n return [];\n } finally {\n state.loadingFeatured = false;\n }\n },\n\n async fetchPlaylistByUrl(url) {\n try {\n const response = await fetch(`${process.env.API_URL}/api/playlists/url/${url}`);\n const playlist = await response.json();\n state.currentPlaylist = playlist;\n\n // Extract tracks from the playlist\n state.currentPlaylistTracks = playlist.tracks?.map(item => item.track) || [];\n\n return playlist;\n } catch (error) {\n console.error('Error fetching playlist by URL:', error);\n return null;\n }\n },\n\n async createPlaylist(playlistData) {\n try {\n const createdPlaylist = await playlistStore.create(playlistData);\n // Update local state\n state.playlists.unshift(createdPlaylist);\n state.userPlaylists.unshift(createdPlaylist);\n return createdPlaylist;\n } catch (error) {\n console.error('Error creating playlist:', error);\n throw error;\n }\n },\n\n async updatePlaylist(playlistData) {\n try {\n const updatedPlaylist = await playlistStore.update(playlistData);\n\n // Update local state\n const index = state.playlists.findIndex(p => p._id === updatedPlaylist._id);\n if (index !== -1) {\n state.playlists[index] = updatedPlaylist;\n }\n\n const userIndex = state.userPlaylists.findIndex(p => p._id === updatedPlaylist._id);\n if (userIndex !== -1) {\n state.userPlaylists[userIndex] = updatedPlaylist;\n }\n\n if (state.currentPlaylist && state.currentPlaylist._id === updatedPlaylist._id) {\n state.currentPlaylist = updatedPlaylist;\n }\n\n return updatedPlaylist;\n } catch (error) {\n console.error('Error updating playlist:', error);\n throw error;\n }\n },\n\n async deletePlaylist(playlistId) {\n try {\n await playlistStore.delete({ _id: playlistId });\n\n // Update local state\n state.playlists = state.playlists.filter(p => p._id !== playlistId);\n state.userPlaylists = state.userPlaylists.filter(p => p._id !== playlistId);\n\n if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {\n state.currentPlaylist = null;\n state.currentPlaylistTracks = [];\n }\n\n return true;\n } catch (error) {\n console.error('Error deleting playlist:', error);\n throw error;\n }\n },\n\n async fetchUserPlaylists(userId) {\n try {\n const response = await fetch(`${process.env.API_URL}/api/playlists/user/${userId || ''}`);\n const playlists = await response.json();\n state.userPlaylists = playlists;\n return playlists;\n } catch (error) {\n console.error('Error fetching user playlists:', error);\n return [];\n }\n },\n\n async addTrackToPlaylist(playlistId, trackId) {\n try {\n const response = await fetch(`${process.env.API_URL}/api/playlists/${playlistId}/tracks/${trackId}`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n });\n\n const updatedPlaylist = await response.json();\n\n // Update local state\n if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {\n state.currentPlaylist = updatedPlaylist;\n // Update tracks list\n const track = updatedPlaylist.tracks.find(item => item.track._id === trackId)?.track;\n if (track && !state.currentPlaylistTracks.some(t => t._id === trackId)) {\n state.currentPlaylistTracks.push(track);\n }\n }\n\n return updatedPlaylist;\n } catch (error) {\n console.error('Error adding track to playlist:', error);\n throw error;\n }\n },\n\n async removeTrackFromPlaylist(playlistId, trackId) {\n try {\n const response = await fetch(`${process.env.API_URL}/api/playlists/${playlistId}/tracks/${trackId}`, {\n method: 'DELETE',\n });\n\n const updatedPlaylist = await response.json();\n\n // Update local state\n if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {\n state.currentPlaylist = updatedPlaylist;\n state.currentPlaylistTracks = state.currentPlaylistTracks.filter(track => track._id !== trackId);\n }\n\n return updatedPlaylist;\n } catch (error) {\n console.error('Error removing track from playlist:', error);\n throw error;\n }\n },\n\n async addCollaborator(playlistId, userId) {\n try {\n const response = await fetch(`${process.env.API_URL}/api/playlists/${playlistId}/collaborators/${userId}`, {\n method: 'POST',\n });\n\n const updatedPlaylist = await response.json();\n\n // Update local state\n if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {\n state.currentPlaylist = updatedPlaylist;\n }\n\n return updatedPlaylist;\n } catch (error) {\n console.error('Error adding collaborator to playlist:', error);\n throw error;\n }\n },\n};\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,109 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ const vue = require("vue");
4
+ const state = vue.reactive({
5
+ query: "",
6
+ results: {
7
+ tracks: [],
8
+ albums: [],
9
+ artists: [],
10
+ playlists: [],
11
+ genres: []
12
+ },
13
+ isLoading: false,
14
+ error: null,
15
+ activeFilter: "all"
16
+ // 'all', 'tracks', 'albums', 'artists', 'playlists', 'genres'
17
+ });
18
+ const actions = {
19
+ async search(query, type = null, limit = 10) {
20
+ if (!query || query.length < 2) {
21
+ state.results = {
22
+ tracks: [],
23
+ albums: [],
24
+ artists: [],
25
+ playlists: [],
26
+ genres: []
27
+ };
28
+ state.error = "Search query must be at least 2 characters";
29
+ return;
30
+ }
31
+ state.query = query;
32
+ state.isLoading = true;
33
+ state.error = null;
34
+ try {
35
+ const queryParams = new URLSearchParams({
36
+ query,
37
+ limit
38
+ });
39
+ if (type) {
40
+ queryParams.append("type", type);
41
+ }
42
+ const response = await fetch(`${process.env.API_URL}/api/music/search?${queryParams.toString()}`);
43
+ if (!response.ok) {
44
+ throw new Error("Search request failed");
45
+ }
46
+ const data = await response.json();
47
+ state.results = {
48
+ tracks: data.tracks || [],
49
+ albums: data.albums || [],
50
+ artists: data.artists || [],
51
+ playlists: data.playlists || [],
52
+ genres: data.genres || []
53
+ };
54
+ } catch (error) {
55
+ console.error("Search error:", error);
56
+ state.error = error.message;
57
+ state.results = {
58
+ tracks: [],
59
+ albums: [],
60
+ artists: [],
61
+ playlists: [],
62
+ genres: []
63
+ };
64
+ } finally {
65
+ state.isLoading = false;
66
+ }
67
+ },
68
+ setFilter(filter) {
69
+ state.activeFilter = filter;
70
+ },
71
+ clearSearch() {
72
+ state.query = "";
73
+ state.results = {
74
+ tracks: [],
75
+ albums: [],
76
+ artists: [],
77
+ playlists: [],
78
+ genres: []
79
+ };
80
+ state.error = null;
81
+ state.isLoading = false;
82
+ }
83
+ };
84
+ const computed = {
85
+ hasResults: () => {
86
+ return Object.values(state.results).some((arr) => arr.length > 0);
87
+ },
88
+ filteredResults: () => {
89
+ if (state.activeFilter === "all") {
90
+ return state.results;
91
+ }
92
+ const filtered = {
93
+ tracks: [],
94
+ albums: [],
95
+ artists: [],
96
+ playlists: [],
97
+ genres: []
98
+ };
99
+ filtered[state.activeFilter] = state.results[state.activeFilter];
100
+ return filtered;
101
+ },
102
+ totalResultsCount: () => {
103
+ return Object.values(state.results).reduce((sum, arr) => sum + arr.length, 0);
104
+ }
105
+ };
106
+ exports.actions = actions;
107
+ exports.computed = computed;
108
+ exports.state = state;
109
+ //# sourceMappingURL=search.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"search.cjs","sources":["../../../../../../src/modules/music/store/search.js"],"sourcesContent":["// store/search.js\nimport { reactive } from 'vue';\n\n// State\nexport const state = reactive({\n query: '',\n results: {\n tracks: [],\n albums: [],\n artists: [],\n playlists: [],\n genres: [],\n },\n isLoading: false,\n error: null,\n activeFilter: 'all', // 'all', 'tracks', 'albums', 'artists', 'playlists', 'genres'\n});\n\n// Actions\nexport const actions = {\n async search(query, type = null, limit = 10) {\n if (!query || query.length < 2) {\n // Reset results if query is too short\n state.results = {\n tracks: [],\n albums: [],\n artists: [],\n playlists: [],\n genres: [],\n };\n state.error = 'Search query must be at least 2 characters';\n return;\n }\n\n state.query = query;\n state.isLoading = true;\n state.error = null;\n\n try {\n const queryParams = new URLSearchParams({\n query,\n limit,\n });\n\n if (type) {\n queryParams.append('type', type);\n }\n\n const response = await fetch(`${process.env.API_URL}/api/music/search?${queryParams.toString()}`);\n\n if (!response.ok) {\n throw new Error('Search request failed');\n }\n\n const data = await response.json();\n\n // Update state with results\n state.results = {\n tracks: data.tracks || [],\n albums: data.albums || [],\n artists: data.artists || [],\n playlists: data.playlists || [],\n genres: data.genres || [],\n };\n } catch (error) {\n console.error('Search error:', error);\n state.error = error.message;\n // Clear results on error\n state.results = {\n tracks: [],\n albums: [],\n artists: [],\n playlists: [],\n genres: [],\n };\n } finally {\n state.isLoading = false;\n }\n },\n\n setFilter(filter) {\n state.activeFilter = filter;\n },\n\n clearSearch() {\n state.query = '';\n state.results = {\n tracks: [],\n albums: [],\n artists: [],\n playlists: [],\n genres: [],\n };\n state.error = null;\n state.isLoading = false;\n },\n};\n\n// Computed values\nexport const computed = {\n hasResults: () => {\n return Object.values(state.results).some(arr => arr.length > 0);\n },\n\n filteredResults: () => {\n if (state.activeFilter === 'all') {\n return state.results;\n }\n\n // Return only the filtered category\n const filtered = {\n tracks: [],\n albums: [],\n artists: [],\n playlists: [],\n genres: [],\n };\n\n filtered[state.activeFilter] = state.results[state.activeFilter];\n return filtered;\n },\n\n totalResultsCount: () => {\n return Object.values(state.results).reduce((sum, arr) => sum + arr.length, 0);\n },\n};\n"],"names":["reactive"],"mappings":";;;AAIY,MAAC,QAAQA,IAAAA,SAAS;AAAA,EAC5B,OAAO;AAAA,EACP,SAAS;AAAA,IACP,QAAQ,CAAE;AAAA,IACV,QAAQ,CAAE;AAAA,IACV,SAAS,CAAE;AAAA,IACX,WAAW,CAAE;AAAA,IACb,QAAQ,CAAE;AAAA,EACX;AAAA,EACD,WAAW;AAAA,EACX,OAAO;AAAA,EACP,cAAc;AAAA;AAChB,CAAC;AAGW,MAAC,UAAU;AAAA,EACrB,MAAM,OAAO,OAAO,OAAO,MAAM,QAAQ,IAAI;AAC3C,QAAI,CAAC,SAAS,MAAM,SAAS,GAAG;AAE9B,YAAM,UAAU;AAAA,QACd,QAAQ,CAAE;AAAA,QACV,QAAQ,CAAE;AAAA,QACV,SAAS,CAAE;AAAA,QACX,WAAW,CAAE;AAAA,QACb,QAAQ,CAAE;AAAA,MACX;AACD,YAAM,QAAQ;AACd;AAAA,IACN;AAEI,UAAM,QAAQ;AACd,UAAM,YAAY;AAClB,UAAM,QAAQ;AAEd,QAAI;AACF,YAAM,cAAc,IAAI,gBAAgB;AAAA,QACtC;AAAA,QACA;AAAA,MACR,CAAO;AAED,UAAI,MAAM;AACR,oBAAY,OAAO,QAAQ,IAAI;AAAA,MACvC;AAEM,YAAM,WAAW,MAAM,MAAM,GAAG,QAAQ,IAAI,OAAO,qBAAqB,YAAY,SAAQ,CAAE,EAAE;AAEhG,UAAI,CAAC,SAAS,IAAI;AAChB,cAAM,IAAI,MAAM,uBAAuB;AAAA,MAC/C;AAEM,YAAM,OAAO,MAAM,SAAS,KAAM;AAGlC,YAAM,UAAU;AAAA,QACd,QAAQ,KAAK,UAAU,CAAE;AAAA,QACzB,QAAQ,KAAK,UAAU,CAAE;AAAA,QACzB,SAAS,KAAK,WAAW,CAAE;AAAA,QAC3B,WAAW,KAAK,aAAa,CAAE;AAAA,QAC/B,QAAQ,KAAK,UAAU,CAAE;AAAA,MAC1B;AAAA,IACF,SAAQ,OAAO;AACd,cAAQ,MAAM,iBAAiB,KAAK;AACpC,YAAM,QAAQ,MAAM;AAEpB,YAAM,UAAU;AAAA,QACd,QAAQ,CAAE;AAAA,QACV,QAAQ,CAAE;AAAA,QACV,SAAS,CAAE;AAAA,QACX,WAAW,CAAE;AAAA,QACb,QAAQ,CAAE;AAAA,MACX;AAAA,IACP,UAAc;AACR,YAAM,YAAY;AAAA,IACxB;AAAA,EACG;AAAA,EAED,UAAU,QAAQ;AAChB,UAAM,eAAe;AAAA,EACtB;AAAA,EAED,cAAc;AACZ,UAAM,QAAQ;AACd,UAAM,UAAU;AAAA,MACd,QAAQ,CAAE;AAAA,MACV,QAAQ,CAAE;AAAA,MACV,SAAS,CAAE;AAAA,MACX,WAAW,CAAE;AAAA,MACb,QAAQ,CAAE;AAAA,IACX;AACD,UAAM,QAAQ;AACd,UAAM,YAAY;AAAA,EACnB;AACH;AAGY,MAAC,WAAW;AAAA,EACtB,YAAY,MAAM;AAChB,WAAO,OAAO,OAAO,MAAM,OAAO,EAAE,KAAK,SAAO,IAAI,SAAS,CAAC;AAAA,EAC/D;AAAA,EAED,iBAAiB,MAAM;AACrB,QAAI,MAAM,iBAAiB,OAAO;AAChC,aAAO,MAAM;AAAA,IACnB;AAGI,UAAM,WAAW;AAAA,MACf,QAAQ,CAAE;AAAA,MACV,QAAQ,CAAE;AAAA,MACV,SAAS,CAAE;AAAA,MACX,WAAW,CAAE;AAAA,MACb,QAAQ,CAAE;AAAA,IACX;AAED,aAAS,MAAM,YAAY,IAAI,MAAM,QAAQ,MAAM,YAAY;AAC/D,WAAO;AAAA,EACR;AAAA,EAED,mBAAmB,MAAM;AACvB,WAAO,OAAO,OAAO,MAAM,OAAO,EAAE,OAAO,CAAC,KAAK,QAAQ,MAAM,IAAI,QAAQ,CAAC;AAAA,EAC7E;AACH;;;;"}
@@ -0,0 +1,109 @@
1
+ import { reactive } from "vue";
2
+ const state = reactive({
3
+ query: "",
4
+ results: {
5
+ tracks: [],
6
+ albums: [],
7
+ artists: [],
8
+ playlists: [],
9
+ genres: []
10
+ },
11
+ isLoading: false,
12
+ error: null,
13
+ activeFilter: "all"
14
+ // 'all', 'tracks', 'albums', 'artists', 'playlists', 'genres'
15
+ });
16
+ const actions = {
17
+ async search(query, type = null, limit = 10) {
18
+ if (!query || query.length < 2) {
19
+ state.results = {
20
+ tracks: [],
21
+ albums: [],
22
+ artists: [],
23
+ playlists: [],
24
+ genres: []
25
+ };
26
+ state.error = "Search query must be at least 2 characters";
27
+ return;
28
+ }
29
+ state.query = query;
30
+ state.isLoading = true;
31
+ state.error = null;
32
+ try {
33
+ const queryParams = new URLSearchParams({
34
+ query,
35
+ limit
36
+ });
37
+ if (type) {
38
+ queryParams.append("type", type);
39
+ }
40
+ const response = await fetch(`${process.env.API_URL}/api/music/search?${queryParams.toString()}`);
41
+ if (!response.ok) {
42
+ throw new Error("Search request failed");
43
+ }
44
+ const data = await response.json();
45
+ state.results = {
46
+ tracks: data.tracks || [],
47
+ albums: data.albums || [],
48
+ artists: data.artists || [],
49
+ playlists: data.playlists || [],
50
+ genres: data.genres || []
51
+ };
52
+ } catch (error) {
53
+ console.error("Search error:", error);
54
+ state.error = error.message;
55
+ state.results = {
56
+ tracks: [],
57
+ albums: [],
58
+ artists: [],
59
+ playlists: [],
60
+ genres: []
61
+ };
62
+ } finally {
63
+ state.isLoading = false;
64
+ }
65
+ },
66
+ setFilter(filter) {
67
+ state.activeFilter = filter;
68
+ },
69
+ clearSearch() {
70
+ state.query = "";
71
+ state.results = {
72
+ tracks: [],
73
+ albums: [],
74
+ artists: [],
75
+ playlists: [],
76
+ genres: []
77
+ };
78
+ state.error = null;
79
+ state.isLoading = false;
80
+ }
81
+ };
82
+ const computed = {
83
+ hasResults: () => {
84
+ return Object.values(state.results).some((arr) => arr.length > 0);
85
+ },
86
+ filteredResults: () => {
87
+ if (state.activeFilter === "all") {
88
+ return state.results;
89
+ }
90
+ const filtered = {
91
+ tracks: [],
92
+ albums: [],
93
+ artists: [],
94
+ playlists: [],
95
+ genres: []
96
+ };
97
+ filtered[state.activeFilter] = state.results[state.activeFilter];
98
+ return filtered;
99
+ },
100
+ totalResultsCount: () => {
101
+ return Object.values(state.results).reduce((sum, arr) => sum + arr.length, 0);
102
+ }
103
+ };
104
+ export {
105
+ actions,
106
+ computed,
107
+ state
108
+ };
109
+ //# sourceMappingURL=search.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"search.js","sources":["../../../../../../src/modules/music/store/search.js"],"sourcesContent":["// store/search.js\nimport { reactive } from 'vue';\n\n// State\nexport const state = reactive({\n query: '',\n results: {\n tracks: [],\n albums: [],\n artists: [],\n playlists: [],\n genres: [],\n },\n isLoading: false,\n error: null,\n activeFilter: 'all', // 'all', 'tracks', 'albums', 'artists', 'playlists', 'genres'\n});\n\n// Actions\nexport const actions = {\n async search(query, type = null, limit = 10) {\n if (!query || query.length < 2) {\n // Reset results if query is too short\n state.results = {\n tracks: [],\n albums: [],\n artists: [],\n playlists: [],\n genres: [],\n };\n state.error = 'Search query must be at least 2 characters';\n return;\n }\n\n state.query = query;\n state.isLoading = true;\n state.error = null;\n\n try {\n const queryParams = new URLSearchParams({\n query,\n limit,\n });\n\n if (type) {\n queryParams.append('type', type);\n }\n\n const response = await fetch(`${process.env.API_URL}/api/music/search?${queryParams.toString()}`);\n\n if (!response.ok) {\n throw new Error('Search request failed');\n }\n\n const data = await response.json();\n\n // Update state with results\n state.results = {\n tracks: data.tracks || [],\n albums: data.albums || [],\n artists: data.artists || [],\n playlists: data.playlists || [],\n genres: data.genres || [],\n };\n } catch (error) {\n console.error('Search error:', error);\n state.error = error.message;\n // Clear results on error\n state.results = {\n tracks: [],\n albums: [],\n artists: [],\n playlists: [],\n genres: [],\n };\n } finally {\n state.isLoading = false;\n }\n },\n\n setFilter(filter) {\n state.activeFilter = filter;\n },\n\n clearSearch() {\n state.query = '';\n state.results = {\n tracks: [],\n albums: [],\n artists: [],\n playlists: [],\n genres: [],\n };\n state.error = null;\n state.isLoading = false;\n },\n};\n\n// Computed values\nexport const computed = {\n hasResults: () => {\n return Object.values(state.results).some(arr => arr.length > 0);\n },\n\n filteredResults: () => {\n if (state.activeFilter === 'all') {\n return state.results;\n }\n\n // Return only the filtered category\n const filtered = {\n tracks: [],\n albums: [],\n artists: [],\n playlists: [],\n genres: [],\n };\n\n filtered[state.activeFilter] = state.results[state.activeFilter];\n return filtered;\n },\n\n totalResultsCount: () => {\n return Object.values(state.results).reduce((sum, arr) => sum + arr.length, 0);\n },\n};\n"],"names":[],"mappings":";AAIY,MAAC,QAAQ,SAAS;AAAA,EAC5B,OAAO;AAAA,EACP,SAAS;AAAA,IACP,QAAQ,CAAE;AAAA,IACV,QAAQ,CAAE;AAAA,IACV,SAAS,CAAE;AAAA,IACX,WAAW,CAAE;AAAA,IACb,QAAQ,CAAE;AAAA,EACX;AAAA,EACD,WAAW;AAAA,EACX,OAAO;AAAA,EACP,cAAc;AAAA;AAChB,CAAC;AAGW,MAAC,UAAU;AAAA,EACrB,MAAM,OAAO,OAAO,OAAO,MAAM,QAAQ,IAAI;AAC3C,QAAI,CAAC,SAAS,MAAM,SAAS,GAAG;AAE9B,YAAM,UAAU;AAAA,QACd,QAAQ,CAAE;AAAA,QACV,QAAQ,CAAE;AAAA,QACV,SAAS,CAAE;AAAA,QACX,WAAW,CAAE;AAAA,QACb,QAAQ,CAAE;AAAA,MACX;AACD,YAAM,QAAQ;AACd;AAAA,IACN;AAEI,UAAM,QAAQ;AACd,UAAM,YAAY;AAClB,UAAM,QAAQ;AAEd,QAAI;AACF,YAAM,cAAc,IAAI,gBAAgB;AAAA,QACtC;AAAA,QACA;AAAA,MACR,CAAO;AAED,UAAI,MAAM;AACR,oBAAY,OAAO,QAAQ,IAAI;AAAA,MACvC;AAEM,YAAM,WAAW,MAAM,MAAM,GAAG,QAAQ,IAAI,OAAO,qBAAqB,YAAY,SAAQ,CAAE,EAAE;AAEhG,UAAI,CAAC,SAAS,IAAI;AAChB,cAAM,IAAI,MAAM,uBAAuB;AAAA,MAC/C;AAEM,YAAM,OAAO,MAAM,SAAS,KAAM;AAGlC,YAAM,UAAU;AAAA,QACd,QAAQ,KAAK,UAAU,CAAE;AAAA,QACzB,QAAQ,KAAK,UAAU,CAAE;AAAA,QACzB,SAAS,KAAK,WAAW,CAAE;AAAA,QAC3B,WAAW,KAAK,aAAa,CAAE;AAAA,QAC/B,QAAQ,KAAK,UAAU,CAAE;AAAA,MAC1B;AAAA,IACF,SAAQ,OAAO;AACd,cAAQ,MAAM,iBAAiB,KAAK;AACpC,YAAM,QAAQ,MAAM;AAEpB,YAAM,UAAU;AAAA,QACd,QAAQ,CAAE;AAAA,QACV,QAAQ,CAAE;AAAA,QACV,SAAS,CAAE;AAAA,QACX,WAAW,CAAE;AAAA,QACb,QAAQ,CAAE;AAAA,MACX;AAAA,IACP,UAAc;AACR,YAAM,YAAY;AAAA,IACxB;AAAA,EACG;AAAA,EAED,UAAU,QAAQ;AAChB,UAAM,eAAe;AAAA,EACtB;AAAA,EAED,cAAc;AACZ,UAAM,QAAQ;AACd,UAAM,UAAU;AAAA,MACd,QAAQ,CAAE;AAAA,MACV,QAAQ,CAAE;AAAA,MACV,SAAS,CAAE;AAAA,MACX,WAAW,CAAE;AAAA,MACb,QAAQ,CAAE;AAAA,IACX;AACD,UAAM,QAAQ;AACd,UAAM,YAAY;AAAA,EACnB;AACH;AAGY,MAAC,WAAW;AAAA,EACtB,YAAY,MAAM;AAChB,WAAO,OAAO,OAAO,MAAM,OAAO,EAAE,KAAK,SAAO,IAAI,SAAS,CAAC;AAAA,EAC/D;AAAA,EAED,iBAAiB,MAAM;AACrB,QAAI,MAAM,iBAAiB,OAAO;AAChC,aAAO,MAAM;AAAA,IACnB;AAGI,UAAM,WAAW;AAAA,MACf,QAAQ,CAAE;AAAA,MACV,QAAQ,CAAE;AAAA,MACV,SAAS,CAAE;AAAA,MACX,WAAW,CAAE;AAAA,MACb,QAAQ,CAAE;AAAA,IACX;AAED,aAAS,MAAM,YAAY,IAAI,MAAM,QAAQ,MAAM,YAAY;AAC/D,WAAO;AAAA,EACR;AAAA,EAED,mBAAmB,MAAM;AACvB,WAAO,OAAO,OAAO,MAAM,OAAO,EAAE,OAAO,CAAC,KAAK,QAAQ,MAAM,IAAI,QAAQ,CAAC;AAAA,EAC7E;AACH;"}