@ozdao/martyrs 0.2.470 → 0.2.472

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 (284) hide show
  1. package/dist/{Media-CR0V1zvB.js → Media-DW8RLbfM.js} +1 -1
  2. package/dist/{Media-C4Ges_Sd.mjs → Media-y_TX6us_.mjs} +1 -1
  3. package/dist/_virtual/index.cjs +1 -1
  4. package/dist/_virtual/index.js +1 -1
  5. package/dist/auth.server.js +1 -1
  6. package/dist/auth.server.mjs +1 -1
  7. package/dist/chats.server.js +1 -1
  8. package/dist/chats.server.mjs +1 -1
  9. package/dist/community.server.js +1 -1
  10. package/dist/community.server.mjs +1 -1
  11. package/dist/events.server.js +1 -1
  12. package/dist/events.server.mjs +1 -1
  13. package/dist/files.server.js +1 -1
  14. package/dist/files.server.mjs +1 -1
  15. package/dist/gallery.server.js +1 -1
  16. package/dist/gallery.server.mjs +1 -1
  17. package/dist/{index-DQqZReAr.js → index-CVXl1rB5.js} +0 -1
  18. package/dist/{index-DICZTQ-1.mjs → index-Df8vtZx7.mjs} +0 -1
  19. package/dist/{main-CsZAG5Wz.js → main-CCfQH-Dd.js} +2 -2
  20. package/dist/{main-CTcal9qN.mjs → main-CgmHzhq5.mjs} +74 -74
  21. package/dist/{node_modules/.pnpm/@vue_server-renderer@3.5.13_vue@3.5.13_typescript@5.8.3_ → martyrs}/node_modules/@vue/server-renderer/dist/server-renderer.esm-bundler.cjs +1 -1
  22. package/dist/martyrs/node_modules/@vue/server-renderer/dist/server-renderer.esm-bundler.cjs.map +1 -0
  23. package/dist/{node_modules/.pnpm/@vue_server-renderer@3.5.13_vue@3.5.13_typescript@5.8.3_ → martyrs}/node_modules/@vue/server-renderer/dist/server-renderer.esm-bundler.js +1 -1
  24. package/dist/martyrs/node_modules/@vue/server-renderer/dist/server-renderer.esm-bundler.js.map +1 -0
  25. package/dist/martyrs/node_modules/@vue/shared/dist/shared.esm-bundler.cjs.map +1 -0
  26. package/dist/martyrs/node_modules/@vue/shared/dist/shared.esm-bundler.js.map +1 -0
  27. package/dist/martyrs/node_modules/uuid/dist/esm-browser/regex.cjs +5 -0
  28. package/dist/martyrs/node_modules/uuid/dist/esm-browser/regex.cjs.map +1 -0
  29. package/dist/martyrs/node_modules/uuid/dist/esm-browser/regex.js +5 -0
  30. package/dist/martyrs/node_modules/uuid/dist/esm-browser/regex.js.map +1 -0
  31. package/dist/{node_modules/.pnpm/uuid@11.1.0 → martyrs}/node_modules/uuid/dist/esm-browser/rng.cjs +4 -4
  32. package/dist/martyrs/node_modules/uuid/dist/esm-browser/rng.cjs.map +1 -0
  33. package/dist/martyrs/node_modules/uuid/dist/esm-browser/rng.js +15 -0
  34. package/dist/martyrs/node_modules/uuid/dist/esm-browser/rng.js.map +1 -0
  35. package/dist/martyrs/node_modules/uuid/dist/esm-browser/stringify.cjs +17 -0
  36. package/dist/martyrs/node_modules/uuid/dist/esm-browser/stringify.cjs.map +1 -0
  37. package/dist/martyrs/node_modules/uuid/dist/esm-browser/stringify.js +17 -0
  38. package/dist/martyrs/node_modules/uuid/dist/esm-browser/stringify.js.map +1 -0
  39. package/dist/martyrs/node_modules/uuid/dist/esm-browser/v4.cjs +13 -0
  40. package/dist/martyrs/node_modules/uuid/dist/esm-browser/v4.cjs.map +1 -0
  41. package/dist/martyrs/node_modules/uuid/dist/esm-browser/v4.js +13 -0
  42. package/dist/martyrs/node_modules/uuid/dist/esm-browser/v4.js.map +1 -0
  43. package/dist/martyrs/node_modules/uuid/dist/esm-browser/validate.cjs +8 -0
  44. package/dist/martyrs/node_modules/uuid/dist/esm-browser/validate.cjs.map +1 -0
  45. package/dist/martyrs/node_modules/uuid/dist/esm-browser/validate.js +8 -0
  46. package/dist/martyrs/node_modules/uuid/dist/esm-browser/validate.js.map +1 -0
  47. package/dist/martyrs/src/components/Feed/Feed.vue.cjs +2 -2
  48. package/dist/martyrs/src/components/Feed/Feed.vue.cjs.map +1 -1
  49. package/dist/martyrs/src/components/Feed/Feed.vue.js +2 -2
  50. package/dist/martyrs/src/components/Feed/Feed.vue.js.map +1 -1
  51. package/dist/martyrs/src/components/Menu/{Menu.vue.cjs → Menu.vue2.cjs} +2 -2
  52. package/dist/martyrs/src/components/Menu/Menu.vue2.cjs.map +1 -0
  53. package/dist/martyrs/src/components/Menu/{Menu.vue.js → Menu.vue2.js} +2 -2
  54. package/dist/martyrs/src/components/Menu/Menu.vue2.js.map +1 -0
  55. package/dist/martyrs/src/components/Skeleton/Skeleton.vue.cjs +5 -5
  56. package/dist/martyrs/src/components/Skeleton/Skeleton.vue.cjs.map +1 -1
  57. package/dist/martyrs/src/components/Skeleton/Skeleton.vue.js +5 -5
  58. package/dist/martyrs/src/components/Skeleton/Skeleton.vue.js.map +1 -1
  59. package/dist/martyrs/src/components/Tab/{Tab.vue2.cjs → Tab.vue.cjs} +2 -2
  60. package/dist/martyrs/src/components/Tab/{Tab.vue2.js.map → Tab.vue.cjs.map} +1 -1
  61. package/dist/martyrs/src/components/Tab/{Tab.vue2.js → Tab.vue.js} +2 -2
  62. package/dist/martyrs/src/components/Tab/Tab.vue.js.map +1 -0
  63. package/dist/martyrs/src/components/Tree/Tree.vue.cjs +3 -1
  64. package/dist/martyrs/src/components/Tree/Tree.vue.cjs.map +1 -1
  65. package/dist/martyrs/src/components/Tree/Tree.vue.js +3 -1
  66. package/dist/martyrs/src/components/Tree/Tree.vue.js.map +1 -1
  67. package/dist/martyrs/src/modules/auth/views/components/layouts/Auth.vue.cjs +1 -1
  68. package/dist/martyrs/src/modules/auth/views/components/layouts/Auth.vue.js +1 -1
  69. package/dist/martyrs/src/modules/auth/views/components/pages/EnterPassword.vue.cjs +1 -1
  70. package/dist/martyrs/src/modules/auth/views/components/pages/EnterPassword.vue.js +1 -1
  71. package/dist/martyrs/src/modules/auth/views/components/pages/Invite.vue.cjs +1 -1
  72. package/dist/martyrs/src/modules/auth/views/components/pages/Invite.vue.js +1 -1
  73. package/dist/martyrs/src/modules/auth/views/components/pages/Profile.vue.cjs +1 -1
  74. package/dist/martyrs/src/modules/auth/views/components/pages/Profile.vue.js +1 -1
  75. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileBlogposts.vue.cjs +1 -1
  76. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileBlogposts.vue.js +1 -1
  77. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEdit.vue.cjs +1 -1
  78. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEdit.vue.js +1 -1
  79. package/dist/martyrs/src/modules/auth/views/components/pages/ResetPassword.vue.cjs +1 -1
  80. package/dist/martyrs/src/modules/auth/views/components/pages/ResetPassword.vue.js +1 -1
  81. package/dist/martyrs/src/modules/auth/views/components/pages/SignIn.vue.cjs +1 -1
  82. package/dist/martyrs/src/modules/auth/views/components/pages/SignIn.vue.js +1 -1
  83. package/dist/martyrs/src/modules/auth/views/components/pages/SignUp.vue.cjs +1 -1
  84. package/dist/martyrs/src/modules/auth/views/components/pages/SignUp.vue.js +1 -1
  85. package/dist/martyrs/src/modules/auth/views/store/auth.cjs +1 -0
  86. package/dist/martyrs/src/modules/auth/views/store/auth.cjs.map +1 -1
  87. package/dist/martyrs/src/modules/auth/views/store/auth.js +1 -0
  88. package/dist/martyrs/src/modules/auth/views/store/auth.js.map +1 -1
  89. package/dist/martyrs/src/modules/constructor/components/sections/Constructor.vue.cjs +1 -1
  90. package/dist/martyrs/src/modules/constructor/components/sections/Constructor.vue.js +1 -1
  91. package/dist/martyrs/src/modules/events/components/pages/EventsBackoffice.vue.cjs +1 -1
  92. package/dist/martyrs/src/modules/events/components/pages/EventsBackoffice.vue.js +1 -1
  93. package/dist/martyrs/src/modules/globals/views/classes/globals.store.cjs +107 -21
  94. package/dist/martyrs/src/modules/globals/views/classes/globals.store.cjs.map +1 -1
  95. package/dist/martyrs/src/modules/globals/views/classes/globals.store.js +107 -21
  96. package/dist/martyrs/src/modules/globals/views/classes/globals.store.js.map +1 -1
  97. package/dist/martyrs/src/modules/globals/views/components/partials/Navigation.vue.cjs +10 -14
  98. package/dist/martyrs/src/modules/globals/views/components/partials/Navigation.vue.cjs.map +1 -1
  99. package/dist/martyrs/src/modules/globals/views/components/partials/Navigation.vue.js +12 -16
  100. package/dist/martyrs/src/modules/globals/views/components/partials/Navigation.vue.js.map +1 -1
  101. package/dist/martyrs/src/modules/globals/views/components/sections/SectionPageTitle.vue.cjs +1 -1
  102. package/dist/martyrs/src/modules/globals/views/components/sections/SectionPageTitle.vue.js +1 -1
  103. package/dist/martyrs/src/modules/globals/views/utils/vue-app-renderer.cjs +7 -13
  104. package/dist/martyrs/src/modules/globals/views/utils/vue-app-renderer.cjs.map +1 -1
  105. package/dist/martyrs/src/modules/globals/views/utils/vue-app-renderer.js +7 -13
  106. package/dist/martyrs/src/modules/globals/views/utils/vue-app-renderer.js.map +1 -1
  107. package/dist/martyrs/src/modules/orders/components/pages/OrderCreate.vue.cjs +6 -7
  108. package/dist/martyrs/src/modules/orders/components/pages/OrderCreate.vue.cjs.map +1 -1
  109. package/dist/martyrs/src/modules/orders/components/pages/OrderCreate.vue.js +7 -8
  110. package/dist/martyrs/src/modules/orders/components/pages/OrderCreate.vue.js.map +1 -1
  111. package/dist/martyrs/src/modules/orders/components/pages/OrderCreateBackoffice.vue.cjs +1 -1
  112. package/dist/martyrs/src/modules/orders/components/pages/OrderCreateBackoffice.vue.js +1 -1
  113. package/dist/martyrs/src/modules/orders/components/pages/Orders.vue.cjs +1 -1
  114. package/dist/martyrs/src/modules/orders/components/pages/Orders.vue.js +1 -1
  115. package/dist/martyrs/src/modules/organizations/components/pages/DepartmentEdit.vue.cjs +1 -1
  116. package/dist/martyrs/src/modules/organizations/components/pages/DepartmentEdit.vue.js +1 -1
  117. package/dist/martyrs/src/modules/organizations/components/pages/Members.vue.cjs +2 -2
  118. package/dist/martyrs/src/modules/organizations/components/pages/Members.vue.js +2 -2
  119. package/dist/martyrs/src/modules/organizations/components/pages/Organization.vue.cjs +2 -2
  120. package/dist/martyrs/src/modules/organizations/components/pages/Organization.vue.js +2 -2
  121. package/dist/martyrs/src/modules/organizations/components/pages/OrganizationBackoffice.vue.cjs +1 -1
  122. package/dist/martyrs/src/modules/organizations/components/pages/OrganizationBackoffice.vue.js +1 -1
  123. package/dist/martyrs/src/modules/organizations/components/pages/OrganizationEdit.vue.cjs +1 -1
  124. package/dist/martyrs/src/modules/organizations/components/pages/OrganizationEdit.vue.js +1 -1
  125. package/dist/martyrs/src/modules/organizations/components/pages/Organizations.vue.cjs +1 -1
  126. package/dist/martyrs/src/modules/organizations/components/pages/Organizations.vue.js +1 -1
  127. package/dist/martyrs/src/modules/organizations/components/sections/Organizations.vue.cjs +1 -1
  128. package/dist/martyrs/src/modules/organizations/components/sections/Organizations.vue.js +1 -1
  129. package/dist/martyrs/src/modules/products/components/blocks/CardCategory.vue.cjs +11 -5
  130. package/dist/martyrs/src/modules/products/components/blocks/CardCategory.vue.cjs.map +1 -1
  131. package/dist/martyrs/src/modules/products/components/blocks/CardCategory.vue.js +12 -6
  132. package/dist/martyrs/src/modules/products/components/blocks/CardCategory.vue.js.map +1 -1
  133. package/dist/martyrs/src/modules/products/components/pages/Categories.vue.cjs +34 -13
  134. package/dist/martyrs/src/modules/products/components/pages/Categories.vue.cjs.map +1 -1
  135. package/dist/martyrs/src/modules/products/components/pages/Categories.vue.js +35 -14
  136. package/dist/martyrs/src/modules/products/components/pages/Categories.vue.js.map +1 -1
  137. package/dist/martyrs/src/modules/products/components/pages/CategoryEdit.vue.cjs +20 -9
  138. package/dist/martyrs/src/modules/products/components/pages/CategoryEdit.vue.cjs.map +1 -1
  139. package/dist/martyrs/src/modules/products/components/pages/CategoryEdit.vue.js +21 -10
  140. package/dist/martyrs/src/modules/products/components/pages/CategoryEdit.vue.js.map +1 -1
  141. package/dist/martyrs/src/modules/products/components/pages/Leftovers.vue.cjs +1 -1
  142. package/dist/martyrs/src/modules/products/components/pages/Leftovers.vue.js +1 -1
  143. package/dist/martyrs/src/modules/products/components/pages/Product.vue.cjs +1 -1
  144. package/dist/martyrs/src/modules/products/components/pages/Product.vue.js +1 -1
  145. package/dist/martyrs/src/modules/products/components/pages/ProductEdit.vue.cjs +2 -1
  146. package/dist/martyrs/src/modules/products/components/pages/ProductEdit.vue.cjs.map +1 -1
  147. package/dist/martyrs/src/modules/products/components/pages/ProductEdit.vue.js +2 -1
  148. package/dist/martyrs/src/modules/products/components/pages/ProductEdit.vue.js.map +1 -1
  149. package/dist/martyrs/src/modules/products/components/pages/Products.vue.cjs +1 -1
  150. package/dist/martyrs/src/modules/products/components/pages/Products.vue.js +1 -1
  151. package/dist/martyrs/src/modules/products/components/sections/SectionProduct.vue.cjs +1 -1
  152. package/dist/martyrs/src/modules/products/components/sections/SectionProduct.vue.js +1 -1
  153. package/dist/martyrs/src/modules/rents/views/components/pages/GanttChart.vue.cjs +1 -1
  154. package/dist/martyrs/src/modules/rents/views/components/pages/GanttChart.vue.js +1 -1
  155. package/dist/martyrs/src/modules/rents/views/components/pages/Rents.vue.cjs +1 -1
  156. package/dist/martyrs/src/modules/rents/views/components/pages/Rents.vue.js +1 -1
  157. package/dist/martyrs/src/modules/spots/components/pages/SpotEdit.vue.cjs +1 -1
  158. package/dist/martyrs/src/modules/spots/components/pages/SpotEdit.vue.js +1 -1
  159. package/dist/martyrs.cjs.js +1 -1
  160. package/dist/martyrs.css +1 -1
  161. package/dist/martyrs.es.js +1 -1
  162. package/dist/notifications.server.js +35 -2
  163. package/dist/notifications.server.mjs +35 -2
  164. package/dist/orders.server.js +3 -3
  165. package/dist/orders.server.mjs +3 -3
  166. package/dist/organizations.server.js +1 -1
  167. package/dist/organizations.server.mjs +1 -1
  168. package/dist/products.server.js +78 -53
  169. package/dist/products.server.mjs +78 -53
  170. package/dist/rents.server.js +1 -1
  171. package/dist/rents.server.mjs +1 -1
  172. package/dist/style.css +37 -38
  173. package/dist/wallet.server.js +1 -1
  174. package/dist/wallet.server.mjs +1 -1
  175. package/package.json +2 -1
  176. package/src/components/Feed/Feed.vue +2 -7
  177. package/src/components/Skeleton/Skeleton.vue +4 -5
  178. package/src/components/Tree/Tree.vue +5 -2
  179. package/src/modules/auth/controllers/middlewares/authJwt.js +1 -1
  180. package/src/modules/auth/views/store/auth.js +2 -1
  181. package/src/modules/globals/controllers/classes/globals.crud.js +2 -2
  182. package/src/modules/globals/views/classes/globals.store.js +119 -31
  183. package/src/modules/globals/views/components/partials/Navigation.vue +11 -10
  184. package/src/modules/globals/views/utils/vue-app-renderer.js +7 -16
  185. package/src/modules/icons/entities/IconMusic.vue +14 -0
  186. package/src/modules/icons/navigation/IconCheck.vue +31 -0
  187. package/src/modules/icons/navigation/IconHeart.vue +26 -0
  188. package/src/modules/icons/navigation/IconPause.vue +31 -0
  189. package/src/modules/icons/navigation/IconPlay.vue +17 -0
  190. package/src/modules/icons/navigation/IconRefresh.vue +31 -0
  191. package/src/modules/icons/navigation/IconShuffle.vue +31 -0
  192. package/src/modules/icons/navigation/IconVolume.vue +31 -0
  193. package/src/modules/music/components/SidebarMusic.vue +156 -0
  194. package/src/modules/music/components/cards/AlbumCard.vue +107 -0
  195. package/src/modules/music/components/cards/ArtistCard.vue +37 -0
  196. package/src/modules/music/components/cards/PlaylistCard.vue +100 -0
  197. package/src/modules/music/components/cards/TrackCard.vue +86 -0
  198. package/src/modules/music/components/forms/PlaylistForm.vue +156 -0
  199. package/src/modules/music/components/forms/SearchForm.vue +82 -0
  200. package/src/modules/music/components/forms/UploadForm.vue +313 -0
  201. package/src/modules/music/components/layouts/MusicLayout.vue +137 -0
  202. package/src/modules/music/components/lists/AlbumList.vue +25 -0
  203. package/src/modules/music/components/lists/ArtistList.vue +25 -0
  204. package/src/modules/music/components/lists/PlaylistList.vue +25 -0
  205. package/src/modules/music/components/lists/TrackList.vue +175 -0
  206. package/src/modules/music/components/pages/AlbumDetail.vue +265 -0
  207. package/src/modules/music/components/pages/ArtistDetail.vue +247 -0
  208. package/src/modules/music/components/pages/MusicHome.vue +177 -0
  209. package/src/modules/music/components/pages/MusicLibrary.vue +192 -0
  210. package/src/modules/music/components/pages/MusicUpload.vue +44 -0
  211. package/src/modules/music/components/pages/PlaylistDetail.vue +504 -0
  212. package/src/modules/music/components/pages/SearchResults.vue +397 -0
  213. package/src/modules/music/components/pages/TrackDetail.vue +143 -0
  214. package/src/modules/music/components/player/MusicPlayer.vue +202 -0
  215. package/src/modules/music/components/player/TrackProgress.vue +110 -0
  216. package/src/modules/music/components/player/VolumeControl.vue +98 -0
  217. package/src/modules/music/controllers/album.controller.js +98 -0
  218. package/src/modules/music/controllers/artist.controller.js +111 -0
  219. package/src/modules/music/controllers/genre.controller.js +71 -0
  220. package/src/modules/music/controllers/music.controller.js +174 -0
  221. package/src/modules/music/controllers/playlist.controller.js +182 -0
  222. package/src/modules/music/controllers/search.controller.js +103 -0
  223. package/src/modules/music/controllers/stream.controller.js +106 -0
  224. package/src/modules/music/models/album.model.js +61 -0
  225. package/src/modules/music/models/artist.model.js +67 -0
  226. package/src/modules/music/models/genre.model.js +42 -0
  227. package/src/modules/music/models/play-history.model.js +51 -0
  228. package/src/modules/music/models/playlist.model.js +69 -0
  229. package/src/modules/music/models/track.model.js +94 -0
  230. package/src/modules/music/music.client.js +186 -0
  231. package/src/modules/music/music.server.js +114 -0
  232. package/src/modules/music/policies/music.policies.js +84 -0
  233. package/src/modules/music/router/music.js +77 -0
  234. package/src/modules/music/routes/album.routes.js +62 -0
  235. package/src/modules/music/routes/artist.routes.js +67 -0
  236. package/src/modules/music/routes/genre.routes.js +60 -0
  237. package/src/modules/music/routes/music.routes.js +145 -0
  238. package/src/modules/music/routes/playlist.routes.js +99 -0
  239. package/src/modules/music/routes/search.routes.js +10 -0
  240. package/src/modules/music/routes/stream.routes.js +38 -0
  241. package/src/modules/music/store/albums.js +200 -0
  242. package/src/modules/music/store/artists.js +180 -0
  243. package/src/modules/music/store/player.js +397 -0
  244. package/src/modules/music/store/playlists.js +211 -0
  245. package/src/modules/music/store/search.js +126 -0
  246. package/src/modules/music/store/tracks.js +230 -0
  247. package/src/modules/music/websocket/streaming.handler.js +151 -0
  248. package/src/modules/notifications/controllers/notifications.controller.js +44 -1
  249. package/src/modules/notifications/notifications.server.js +0 -1
  250. package/src/modules/notifications/routes/notifications.routes.js +3 -0
  251. package/src/modules/orders/components/pages/OrderCreate.vue +0 -2
  252. package/src/modules/products/components/blocks/CardCategory.vue +5 -4
  253. package/src/modules/products/components/pages/Categories.vue +38 -20
  254. package/src/modules/products/components/pages/CategoryEdit.vue +16 -7
  255. package/src/modules/products/components/pages/ProductEdit.vue +1 -0
  256. package/src/modules/products/controllers/categories.controller.js +155 -103
  257. package/dist/martyrs/src/components/Menu/Menu.vue.cjs.map +0 -1
  258. package/dist/martyrs/src/components/Menu/Menu.vue.js.map +0 -1
  259. package/dist/martyrs/src/components/Tab/Tab.vue2.cjs.map +0 -1
  260. package/dist/node_modules/.pnpm/@vue_server-renderer@3.5.13_vue@3.5.13_typescript@5.8.3_/node_modules/@vue/server-renderer/dist/server-renderer.esm-bundler.cjs.map +0 -1
  261. package/dist/node_modules/.pnpm/@vue_server-renderer@3.5.13_vue@3.5.13_typescript@5.8.3_/node_modules/@vue/server-renderer/dist/server-renderer.esm-bundler.js.map +0 -1
  262. package/dist/node_modules/.pnpm/@vue_shared@3.5.13/node_modules/@vue/shared/dist/shared.esm-bundler.cjs.map +0 -1
  263. package/dist/node_modules/.pnpm/@vue_shared@3.5.13/node_modules/@vue/shared/dist/shared.esm-bundler.js.map +0 -1
  264. package/dist/node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm-browser/native.cjs +0 -6
  265. package/dist/node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm-browser/native.cjs.map +0 -1
  266. package/dist/node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm-browser/native.js +0 -6
  267. package/dist/node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm-browser/native.js.map +0 -1
  268. package/dist/node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm-browser/rng.cjs.map +0 -1
  269. package/dist/node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm-browser/rng.js +0 -15
  270. package/dist/node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm-browser/rng.js.map +0 -1
  271. package/dist/node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm-browser/stringify.cjs +0 -11
  272. package/dist/node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm-browser/stringify.cjs.map +0 -1
  273. package/dist/node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm-browser/stringify.js +0 -11
  274. package/dist/node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm-browser/stringify.js.map +0 -1
  275. package/dist/node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm-browser/v4.cjs +0 -21
  276. package/dist/node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm-browser/v4.cjs.map +0 -1
  277. package/dist/node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm-browser/v4.js +0 -21
  278. package/dist/node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm-browser/v4.js.map +0 -1
  279. /package/dist/{node_modules/.pnpm/@vue_shared@3.5.13 → martyrs}/node_modules/@vue/shared/dist/shared.esm-bundler.cjs +0 -0
  280. /package/dist/{node_modules/.pnpm/@vue_shared@3.5.13 → martyrs}/node_modules/@vue/shared/dist/shared.esm-bundler.js +0 -0
  281. /package/dist/{node_modules → martyrs/node_modules}/fast-deep-equal/index.cjs +0 -0
  282. /package/dist/{node_modules → martyrs/node_modules}/fast-deep-equal/index.cjs.map +0 -0
  283. /package/dist/{node_modules → martyrs/node_modules}/fast-deep-equal/index.js +0 -0
  284. /package/dist/{node_modules → martyrs/node_modules}/fast-deep-equal/index.js.map +0 -0
@@ -0,0 +1,200 @@
1
+ // store/albums.js
2
+ import { reactive } from 'vue';
3
+ import Store from '@martyrs/src/modules/globals/views/classes/globals.store';
4
+
5
+ // Create store instance
6
+ const albumStore = new Store(`${process.env.API_URL}/api/albums`);
7
+
8
+ // State
9
+ export const state = reactive({
10
+ albums: [],
11
+ featured: [],
12
+ userAlbums: [],
13
+ currentAlbum: null,
14
+ currentAlbumTracks: [],
15
+ isLoading: false,
16
+ loadingFeatured: false
17
+ });
18
+
19
+ // Actions
20
+ export const actions = {
21
+ async fetchAlbums(options = {}) {
22
+ state.isLoading = true;
23
+ try {
24
+ const albums = await albumStore.read(options);
25
+ state.albums = albums;
26
+ return albums;
27
+ } catch (error) {
28
+ console.error('Error fetching albums:', error);
29
+ return [];
30
+ } finally {
31
+ state.isLoading = false;
32
+ }
33
+ },
34
+
35
+ async fetchFeaturedAlbums() {
36
+ state.loadingFeatured = true;
37
+ try {
38
+ const response = await fetch(`${process.env.API_URL}/api/albums/featured`);
39
+ const albums = await response.json();
40
+ state.featured = albums;
41
+ return albums;
42
+ } catch (error) {
43
+ console.error('Error fetching featured albums:', error);
44
+ return [];
45
+ } finally {
46
+ state.loadingFeatured = false;
47
+ }
48
+ },
49
+
50
+ async fetchAlbumByUrl(url) {
51
+ try {
52
+ const response = await fetch(`${process.env.API_URL}/api/albums/url/${url}`);
53
+ const album = await response.json();
54
+ state.currentAlbum = album;
55
+
56
+ // Fetch album tracks
57
+ await this.fetchAlbumTracks(album._id);
58
+
59
+ return album;
60
+ } catch (error) {
61
+ console.error('Error fetching album by URL:', error);
62
+ return null;
63
+ }
64
+ },
65
+
66
+ async fetchAlbumTracks(albumId) {
67
+ try {
68
+ const response = await fetch(`${process.env.API_URL}/api/albums/${albumId}/tracks`);
69
+ const tracks = await response.json();
70
+ state.currentAlbumTracks = tracks;
71
+ return tracks;
72
+ } catch (error) {
73
+ console.error('Error fetching album tracks:', error);
74
+ return [];
75
+ }
76
+ },
77
+
78
+ async createAlbum(albumData) {
79
+ try {
80
+ const createdAlbum = await albumStore.create(albumData);
81
+ // Update local state
82
+ state.albums.unshift(createdAlbum);
83
+ state.userAlbums.unshift(createdAlbum);
84
+ return createdAlbum;
85
+ } catch (error) {
86
+ console.error('Error creating album:', error);
87
+ throw error;
88
+ }
89
+ },
90
+
91
+ async updateAlbum(albumData) {
92
+ try {
93
+ const updatedAlbum = await albumStore.update(albumData);
94
+
95
+ // Update local state
96
+ const index = state.albums.findIndex(a => a._id === updatedAlbum._id);
97
+ if (index !== -1) {
98
+ state.albums[index] = updatedAlbum;
99
+ }
100
+
101
+ const userIndex = state.userAlbums.findIndex(a => a._id === updatedAlbum._id);
102
+ if (userIndex !== -1) {
103
+ state.userAlbums[userIndex] = updatedAlbum;
104
+ }
105
+
106
+ if (state.currentAlbum && state.currentAlbum._id === updatedAlbum._id) {
107
+ state.currentAlbum = updatedAlbum;
108
+ }
109
+
110
+ return updatedAlbum;
111
+ } catch (error) {
112
+ console.error('Error updating album:', error);
113
+ throw error;
114
+ }
115
+ },
116
+
117
+ async deleteAlbum(albumId) {
118
+ try {
119
+ await albumStore.delete({ _id: albumId });
120
+
121
+ // Update local state
122
+ state.albums = state.albums.filter(a => a._id !== albumId);
123
+ state.userAlbums = state.userAlbums.filter(a => a._id !== albumId);
124
+
125
+ if (state.currentAlbum && state.currentAlbum._id === albumId) {
126
+ state.currentAlbum = null;
127
+ state.currentAlbumTracks = [];
128
+ }
129
+
130
+ return true;
131
+ } catch (error) {
132
+ console.error('Error deleting album:', error);
133
+ throw error;
134
+ }
135
+ },
136
+
137
+ async fetchUserAlbums(userId) {
138
+ try {
139
+ const options = {
140
+ creator: userId,
141
+ limit: 100
142
+ };
143
+
144
+ const albums = await albumStore.read(options);
145
+ state.userAlbums = albums;
146
+ return albums;
147
+ } catch (error) {
148
+ console.error('Error fetching user albums:', error);
149
+ return [];
150
+ }
151
+ },
152
+
153
+ async addTrackToAlbum(albumId, trackId) {
154
+ try {
155
+ const response = await fetch(`${process.env.API_URL}/api/tracks/${trackId}`, {
156
+ method: 'PUT',
157
+ headers: {
158
+ 'Content-Type': 'application/json'
159
+ },
160
+ body: JSON.stringify({ album: albumId })
161
+ });
162
+
163
+ const updatedTrack = await response.json();
164
+
165
+ // Update the current album tracks if relevant
166
+ if (state.currentAlbum && state.currentAlbum._id === albumId) {
167
+ state.currentAlbumTracks.push(updatedTrack);
168
+ }
169
+
170
+ return updatedTrack;
171
+ } catch (error) {
172
+ console.error('Error adding track to album:', error);
173
+ throw error;
174
+ }
175
+ },
176
+
177
+ async removeTrackFromAlbum(trackId) {
178
+ try {
179
+ const response = await fetch(`${process.env.API_URL}/api/tracks/${trackId}`, {
180
+ method: 'PUT',
181
+ headers: {
182
+ 'Content-Type': 'application/json'
183
+ },
184
+ body: JSON.stringify({ album: null })
185
+ });
186
+
187
+ const updatedTrack = await response.json();
188
+
189
+ // Update the current album tracks if relevant
190
+ if (state.currentAlbumTracks.some(track => track._id === trackId)) {
191
+ state.currentAlbumTracks = state.currentAlbumTracks.filter(track => track._id !== trackId);
192
+ }
193
+
194
+ return updatedTrack;
195
+ } catch (error) {
196
+ console.error('Error removing track from album:', error);
197
+ throw error;
198
+ }
199
+ }
200
+ };
@@ -0,0 +1,180 @@
1
+ // store/artists.js
2
+ import { reactive } from 'vue';
3
+ import Store from '@martyrs/src/modules/globals/views/classes/globals.store';
4
+
5
+ // Create store instance
6
+ const artistStore = new Store(`${process.env.API_URL}/api/artists`);
7
+
8
+ // State
9
+ export const state = reactive({
10
+ artists: [],
11
+ topArtists: [],
12
+ userArtists: [],
13
+ currentArtist: null,
14
+ discography: {
15
+ albums: [],
16
+ singles: []
17
+ },
18
+ relatedArtists: [],
19
+ isLoading: false,
20
+ loadingTopArtists: false
21
+ });
22
+
23
+ // Actions
24
+ export const actions = {
25
+ async fetchArtists(options = {}) {
26
+ state.isLoading = true;
27
+ try {
28
+ const artists = await artistStore.read(options);
29
+ state.artists = artists;
30
+ return artists;
31
+ } catch (error) {
32
+ console.error('Error fetching artists:', error);
33
+ return [];
34
+ } finally {
35
+ state.isLoading = false;
36
+ }
37
+ },
38
+
39
+ async fetchTopArtists(limit = 10) {
40
+ state.loadingTopArtists = true;
41
+ try {
42
+ // Assuming the backend sorts by popularity
43
+ const options = {
44
+ limit,
45
+ sortParam: 'popularity',
46
+ sortOrder: 'desc',
47
+ status: 'published'
48
+ };
49
+
50
+ const artists = await artistStore.read(options);
51
+ state.topArtists = artists;
52
+ return artists;
53
+ } catch (error) {
54
+ console.error('Error fetching top artists:', error);
55
+ return [];
56
+ } finally {
57
+ state.loadingTopArtists = false;
58
+ }
59
+ },
60
+
61
+ async fetchArtistByUrl(url) {
62
+ try {
63
+ const response = await fetch(`${process.env.API_URL}/api/artists/url/${url}`);
64
+ const artist = await response.json();
65
+ state.currentArtist = artist;
66
+
67
+ // Fetch artist discography
68
+ await this.fetchArtistDiscography(artist._id);
69
+
70
+ // Fetch related artists
71
+ await this.fetchRelatedArtists(artist._id);
72
+
73
+ return artist;
74
+ } catch (error) {
75
+ console.error('Error fetching artist by URL:', error);
76
+ return null;
77
+ }
78
+ },
79
+
80
+ async fetchArtistDiscography(artistId) {
81
+ try {
82
+ const response = await fetch(`${process.env.API_URL}/api/artists/${artistId}/discography`);
83
+ const discography = await response.json();
84
+ state.discography = {
85
+ albums: discography.albums || [],
86
+ singles: discography.singles || []
87
+ };
88
+ return discography;
89
+ } catch (error) {
90
+ console.error('Error fetching artist discography:', error);
91
+ return { albums: [], singles: [] };
92
+ }
93
+ },
94
+
95
+ async fetchRelatedArtists(artistId) {
96
+ try {
97
+ const response = await fetch(`${process.env.API_URL}/api/artists/${artistId}/related`);
98
+ const artists = await response.json();
99
+ state.relatedArtists = artists;
100
+ return artists;
101
+ } catch (error) {
102
+ console.error('Error fetching related artists:', error);
103
+ return [];
104
+ }
105
+ },
106
+
107
+ async createArtist(artistData) {
108
+ try {
109
+ const createdArtist = await artistStore.create(artistData);
110
+ // Update local state
111
+ state.artists.unshift(createdArtist);
112
+ state.userArtists.unshift(createdArtist);
113
+ return createdArtist;
114
+ } catch (error) {
115
+ console.error('Error creating artist:', error);
116
+ throw error;
117
+ }
118
+ },
119
+
120
+ async updateArtist(artistData) {
121
+ try {
122
+ const updatedArtist = await artistStore.update(artistData);
123
+
124
+ // Update local state
125
+ const index = state.artists.findIndex(a => a._id === updatedArtist._id);
126
+ if (index !== -1) {
127
+ state.artists[index] = updatedArtist;
128
+ }
129
+
130
+ const userIndex = state.userArtists.findIndex(a => a._id === updatedArtist._id);
131
+ if (userIndex !== -1) {
132
+ state.userArtists[userIndex] = updatedArtist;
133
+ }
134
+
135
+ if (state.currentArtist && state.currentArtist._id === updatedArtist._id) {
136
+ state.currentArtist = updatedArtist;
137
+ }
138
+
139
+ return updatedArtist;
140
+ } catch (error) {
141
+ console.error('Error updating artist:', error);
142
+ throw error;
143
+ }
144
+ },
145
+
146
+ async deleteArtist(artistId) {
147
+ try {
148
+ await artistStore.delete({ _id: artistId });
149
+
150
+ // Update local state
151
+ state.artists = state.artists.filter(a => a._id !== artistId);
152
+ state.userArtists = state.userArtists.filter(a => a._id !== artistId);
153
+
154
+ if (state.currentArtist && state.currentArtist._id === artistId) {
155
+ state.currentArtist = null;
156
+ }
157
+
158
+ return true;
159
+ } catch (error) {
160
+ console.error('Error deleting artist:', error);
161
+ throw error;
162
+ }
163
+ },
164
+
165
+ async fetchUserArtists(userId) {
166
+ try {
167
+ const options = {
168
+ creator: userId,
169
+ limit: 100
170
+ };
171
+
172
+ const artists = await artistStore.read(options);
173
+ state.userArtists = artists;
174
+ return artists;
175
+ } catch (error) {
176
+ console.error('Error fetching user artists:', error);
177
+ return [];
178
+ }
179
+ }
180
+ };