@ozdao/martyrs 0.2.492 → 0.2.494

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 (341) hide show
  1. package/dist/_virtual/index.cjs +4 -4
  2. package/dist/_virtual/index.js +4 -4
  3. package/dist/_virtual/index2.cjs +4 -4
  4. package/dist/_virtual/index2.js +4 -4
  5. package/dist/builder.cjs +53 -90
  6. package/dist/builder.js +54 -91
  7. package/dist/{crud-B-kQw3Z5.cjs → crud-JN_LFj01.cjs} +3 -0
  8. package/dist/{crud-Cwx5VlSm.js → crud-sE7GLPbj.js} +3 -0
  9. package/dist/globals.server.cjs +322 -3
  10. package/dist/globals.server.js +303 -1
  11. package/dist/{globals.verifier-D68mHEBl.cjs → globals.verifier-C0zj_LLo.cjs} +8 -1
  12. package/dist/{globals.verifier-CWFz5Gh2.js → globals.verifier-DFqKQ7hK.js} +8 -1
  13. package/dist/inventory.server.cjs +2 -2
  14. package/dist/inventory.server.js +2 -2
  15. package/dist/{main-SZQ1QjeP.js → main-CJm5myDI.js} +631 -607
  16. package/dist/{main-MzmGbSxs.cjs → main-DTaE01lg.cjs} +6 -6
  17. package/dist/martyrs/src/components/Calendar/Calendar.vue2.cjs +1 -1
  18. package/dist/martyrs/src/components/Calendar/Calendar.vue2.cjs.map +1 -1
  19. package/dist/martyrs/src/components/Calendar/Calendar.vue2.js +1 -1
  20. package/dist/martyrs/src/components/Calendar/Calendar.vue2.js.map +1 -1
  21. package/dist/martyrs/src/components/Feed/Feed.vue.cjs +33 -7
  22. package/dist/martyrs/src/components/Feed/Feed.vue.cjs.map +1 -1
  23. package/dist/martyrs/src/components/Feed/Feed.vue.js +33 -7
  24. package/dist/martyrs/src/components/Feed/Feed.vue.js.map +1 -1
  25. package/dist/martyrs/src/components/Field/{Field.vue2.cjs → Field.vue.cjs} +2 -2
  26. package/dist/martyrs/src/components/Field/{Field.vue2.js.map → Field.vue.cjs.map} +1 -1
  27. package/dist/martyrs/src/components/Field/{Field.vue2.js → Field.vue.js} +2 -2
  28. package/dist/martyrs/src/components/Field/Field.vue.js.map +1 -0
  29. package/dist/martyrs/src/components/FieldBig/FieldBig.vue.cjs +1 -1
  30. package/dist/martyrs/src/components/FieldBig/FieldBig.vue.js +1 -1
  31. package/dist/martyrs/src/components/FieldTags/FieldTags.vue.cjs +1 -1
  32. package/dist/martyrs/src/components/FieldTags/FieldTags.vue.js +1 -1
  33. package/dist/martyrs/src/components/Menu/{Menu.vue.cjs → Menu.vue2.cjs} +2 -2
  34. package/dist/martyrs/src/components/Menu/Menu.vue2.cjs.map +1 -0
  35. package/dist/martyrs/src/components/Menu/{Menu.vue.js → Menu.vue2.js} +2 -2
  36. package/dist/martyrs/src/components/Menu/Menu.vue2.js.map +1 -0
  37. package/dist/martyrs/src/components/Menu/MenuItem.vue.js +2 -2
  38. package/dist/martyrs/src/components/Menu/MenuItem.vue.js.map +1 -1
  39. package/dist/martyrs/src/components/PhotoViewer/PhotoViewer.vue.js +4 -4
  40. package/dist/martyrs/src/modules/auth/views/components/pages/EnterCode.vue.cjs +1 -1
  41. package/dist/martyrs/src/modules/auth/views/components/pages/EnterCode.vue.js +1 -1
  42. package/dist/martyrs/src/modules/auth/views/components/pages/EnterPassword.vue.cjs +1 -1
  43. package/dist/martyrs/src/modules/auth/views/components/pages/EnterPassword.vue.js +1 -1
  44. package/dist/martyrs/src/modules/auth/views/components/pages/Invite.vue.cjs +1 -1
  45. package/dist/martyrs/src/modules/auth/views/components/pages/Invite.vue.js +1 -1
  46. package/dist/martyrs/src/modules/auth/views/components/pages/Profile.vue.cjs +2 -2
  47. package/dist/martyrs/src/modules/auth/views/components/pages/Profile.vue.js +2 -2
  48. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditProfile.vue.cjs +1 -1
  49. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditProfile.vue.js +1 -1
  50. package/dist/martyrs/src/modules/auth/views/components/pages/ResetPassword.vue.cjs +1 -1
  51. package/dist/martyrs/src/modules/auth/views/components/pages/ResetPassword.vue.js +1 -1
  52. package/dist/martyrs/src/modules/auth/views/components/pages/SignIn.vue.cjs +1 -1
  53. package/dist/martyrs/src/modules/auth/views/components/pages/SignIn.vue.js +1 -1
  54. package/dist/martyrs/src/modules/auth/views/components/pages/SignUp.vue.cjs +1 -1
  55. package/dist/martyrs/src/modules/auth/views/components/pages/SignUp.vue.js +1 -1
  56. package/dist/martyrs/src/modules/auth/views/components/sections/ProfileEditCredentials.vue.cjs +1 -1
  57. package/dist/martyrs/src/modules/auth/views/components/sections/ProfileEditCredentials.vue.js +1 -1
  58. package/dist/martyrs/src/modules/community/components/pages/CreateBlogPost.vue.cjs +2 -2
  59. package/dist/martyrs/src/modules/community/components/pages/CreateBlogPost.vue.js +2 -2
  60. package/dist/martyrs/src/modules/constructor/components/elements/Card.vue.cjs +1 -1
  61. package/dist/martyrs/src/modules/constructor/components/elements/Card.vue.js +1 -1
  62. package/dist/martyrs/src/modules/constructor/components/elements/Embed.vue.cjs +1 -1
  63. package/dist/martyrs/src/modules/constructor/components/elements/Embed.vue.js +1 -1
  64. package/dist/martyrs/src/modules/events/components/pages/EditEvent.vue.cjs +1 -1
  65. package/dist/martyrs/src/modules/events/components/pages/EditEvent.vue.js +1 -1
  66. package/dist/martyrs/src/modules/events/components/pages/EditEventTickets.vue.cjs +1 -1
  67. package/dist/martyrs/src/modules/events/components/pages/EditEventTickets.vue.js +1 -1
  68. package/dist/martyrs/src/modules/events/components/pages/Event.vue.cjs +1 -1
  69. package/dist/martyrs/src/modules/events/components/pages/Event.vue.js +1 -1
  70. package/dist/martyrs/src/modules/gallery/components/sections/BackofficeGallery.vue.cjs +1 -1
  71. package/dist/martyrs/src/modules/gallery/components/sections/BackofficeGallery.vue.js +1 -1
  72. package/dist/martyrs/src/modules/globals/views/classes/globals.i18n.cjs +1 -1
  73. package/dist/martyrs/src/modules/globals/views/classes/globals.i18n.js +1 -1
  74. package/dist/martyrs/src/modules/globals/views/components/blocks/BlockSearch.vue.cjs +1 -1
  75. package/dist/martyrs/src/modules/globals/views/components/blocks/BlockSearch.vue.js +1 -1
  76. package/dist/martyrs/src/modules/globals/views/components/layouts/Client.vue.cjs +5 -1
  77. package/dist/martyrs/src/modules/globals/views/components/layouts/Client.vue.cjs.map +1 -1
  78. package/dist/martyrs/src/modules/globals/views/components/layouts/Client.vue.js +5 -1
  79. package/dist/martyrs/src/modules/globals/views/components/layouts/Client.vue.js.map +1 -1
  80. package/dist/martyrs/src/modules/icons/entities/IconTime.vue.cjs +2 -2
  81. package/dist/martyrs/src/modules/icons/entities/IconTime.vue.js +2 -2
  82. package/dist/martyrs/src/modules/icons/navigation/IconChevronLeft.vue.cjs +2 -2
  83. package/dist/martyrs/src/modules/icons/navigation/IconChevronLeft.vue.js +2 -2
  84. package/dist/martyrs/src/modules/icons/navigation/IconChevronRight.vue.cjs +2 -2
  85. package/dist/martyrs/src/modules/icons/navigation/IconChevronRight.vue.js +2 -2
  86. package/dist/martyrs/src/modules/icons/pages/IconsPage.vue.js +6 -6
  87. package/dist/martyrs/src/modules/icons/pages/IconsPage.vue.js.map +1 -1
  88. package/dist/martyrs/src/modules/inventory/components/forms/AdjustmentForm.vue.cjs +1 -1
  89. package/dist/martyrs/src/modules/inventory/components/forms/AdjustmentForm.vue.js +1 -1
  90. package/dist/martyrs/src/modules/inventory/components/forms/StockAlertsForm.vue.cjs +1 -1
  91. package/dist/martyrs/src/modules/inventory/components/forms/StockAlertsForm.vue.js +1 -1
  92. package/dist/martyrs/src/modules/inventory/components/pages/Inventory.vue.cjs +1 -1
  93. package/dist/martyrs/src/modules/inventory/components/pages/InventoryEdit.vue.cjs +1 -1
  94. package/dist/martyrs/src/modules/inventory/components/pages/InventoryEdit.vue.js +1 -1
  95. package/dist/martyrs/src/modules/music/components/cards/AlbumCard.vue.cjs +22 -15
  96. package/dist/martyrs/src/modules/music/components/cards/AlbumCard.vue.cjs.map +1 -1
  97. package/dist/martyrs/src/modules/music/components/cards/AlbumCard.vue.js +23 -16
  98. package/dist/martyrs/src/modules/music/components/cards/AlbumCard.vue.js.map +1 -1
  99. package/dist/martyrs/src/modules/music/components/cards/ArtistCard.vue.cjs +2 -2
  100. package/dist/martyrs/src/modules/music/components/cards/ArtistCard.vue.cjs.map +1 -1
  101. package/dist/martyrs/src/modules/music/components/cards/ArtistCard.vue.js +2 -2
  102. package/dist/martyrs/src/modules/music/components/cards/ArtistCard.vue.js.map +1 -1
  103. package/dist/martyrs/src/modules/music/components/cards/PlaylistCard.vue.cjs +31 -13
  104. package/dist/martyrs/src/modules/music/components/cards/PlaylistCard.vue.cjs.map +1 -1
  105. package/dist/martyrs/src/modules/music/components/cards/PlaylistCard.vue.js +33 -15
  106. package/dist/martyrs/src/modules/music/components/cards/PlaylistCard.vue.js.map +1 -1
  107. package/dist/martyrs/src/modules/music/components/cards/TrackListCard.vue.cjs +39 -22
  108. package/dist/martyrs/src/modules/music/components/cards/TrackListCard.vue.cjs.map +1 -1
  109. package/dist/martyrs/src/modules/music/components/cards/TrackListCard.vue.js +39 -22
  110. package/dist/martyrs/src/modules/music/components/cards/TrackListCard.vue.js.map +1 -1
  111. package/dist/martyrs/src/modules/music/components/forms/AlbumForm.vue.cjs +1 -1
  112. package/dist/martyrs/src/modules/music/components/forms/AlbumForm.vue.js +1 -1
  113. package/dist/martyrs/src/modules/music/components/forms/ArtistForm.vue.cjs +1 -1
  114. package/dist/martyrs/src/modules/music/components/forms/ArtistForm.vue.js +1 -1
  115. package/dist/martyrs/src/modules/music/components/forms/PlaylistForm.vue.cjs +385 -125
  116. package/dist/martyrs/src/modules/music/components/forms/PlaylistForm.vue.cjs.map +1 -1
  117. package/dist/martyrs/src/modules/music/components/forms/PlaylistForm.vue.js +391 -131
  118. package/dist/martyrs/src/modules/music/components/forms/PlaylistForm.vue.js.map +1 -1
  119. package/dist/martyrs/src/modules/music/components/forms/SearchForm.vue.cjs +24 -7
  120. package/dist/martyrs/src/modules/music/components/forms/SearchForm.vue.cjs.map +1 -1
  121. package/dist/martyrs/src/modules/music/components/forms/SearchForm.vue.js +25 -8
  122. package/dist/martyrs/src/modules/music/components/forms/SearchForm.vue.js.map +1 -1
  123. package/dist/martyrs/src/modules/music/components/forms/TrackForm.vue.cjs +99 -87
  124. package/dist/martyrs/src/modules/music/components/forms/TrackForm.vue.cjs.map +1 -1
  125. package/dist/martyrs/src/modules/music/components/forms/TrackForm.vue.js +111 -99
  126. package/dist/martyrs/src/modules/music/components/forms/TrackForm.vue.js.map +1 -1
  127. package/dist/martyrs/src/modules/music/components/layouts/MusicBottomPlayer.vue.cjs +21 -0
  128. package/dist/martyrs/src/modules/music/components/layouts/MusicBottomPlayer.vue.cjs.map +1 -0
  129. package/dist/martyrs/src/modules/music/components/layouts/MusicBottomPlayer.vue.js +21 -0
  130. package/dist/martyrs/src/modules/music/components/layouts/MusicBottomPlayer.vue.js.map +1 -0
  131. package/dist/martyrs/src/modules/music/components/pages/Album.vue.cjs +442 -210
  132. package/dist/martyrs/src/modules/music/components/pages/Album.vue.cjs.map +1 -1
  133. package/dist/martyrs/src/modules/music/components/pages/Album.vue.js +445 -213
  134. package/dist/martyrs/src/modules/music/components/pages/Album.vue.js.map +1 -1
  135. package/dist/martyrs/src/modules/music/components/pages/Artist.vue.cjs +92 -117
  136. package/dist/martyrs/src/modules/music/components/pages/Artist.vue.cjs.map +1 -1
  137. package/dist/martyrs/src/modules/music/components/pages/Artist.vue.js +93 -118
  138. package/dist/martyrs/src/modules/music/components/pages/Artist.vue.js.map +1 -1
  139. package/dist/martyrs/src/modules/music/components/pages/MusicHome.vue.cjs +72 -113
  140. package/dist/martyrs/src/modules/music/components/pages/MusicHome.vue.cjs.map +1 -1
  141. package/dist/martyrs/src/modules/music/components/pages/MusicHome.vue.js +78 -119
  142. package/dist/martyrs/src/modules/music/components/pages/MusicHome.vue.js.map +1 -1
  143. package/dist/martyrs/src/modules/music/components/pages/MusicLibrary.vue.cjs +15 -12
  144. package/dist/martyrs/src/modules/music/components/pages/MusicLibrary.vue.cjs.map +1 -1
  145. package/dist/martyrs/src/modules/music/components/pages/MusicLibrary.vue.js +15 -12
  146. package/dist/martyrs/src/modules/music/components/pages/MusicLibrary.vue.js.map +1 -1
  147. package/dist/martyrs/src/modules/music/components/pages/Playlist.vue.cjs +558 -429
  148. package/dist/martyrs/src/modules/music/components/pages/Playlist.vue.cjs.map +1 -1
  149. package/dist/martyrs/src/modules/music/components/pages/Playlist.vue.js +560 -431
  150. package/dist/martyrs/src/modules/music/components/pages/Playlist.vue.js.map +1 -1
  151. package/dist/martyrs/src/modules/music/components/pages/SearchResults.vue.cjs +146 -284
  152. package/dist/martyrs/src/modules/music/components/pages/SearchResults.vue.cjs.map +1 -1
  153. package/dist/martyrs/src/modules/music/components/pages/SearchResults.vue.js +149 -287
  154. package/dist/martyrs/src/modules/music/components/pages/SearchResults.vue.js.map +1 -1
  155. package/dist/martyrs/src/modules/music/components/pages/Track.vue.cjs +460 -63
  156. package/dist/martyrs/src/modules/music/components/pages/Track.vue.cjs.map +1 -1
  157. package/dist/martyrs/src/modules/music/components/pages/Track.vue.js +462 -65
  158. package/dist/martyrs/src/modules/music/components/pages/Track.vue.js.map +1 -1
  159. package/dist/martyrs/src/modules/music/components/player/MusicPlayer.vue.cjs +126 -136
  160. package/dist/martyrs/src/modules/music/components/player/MusicPlayer.vue.cjs.map +1 -1
  161. package/dist/martyrs/src/modules/music/components/player/MusicPlayer.vue.js +129 -139
  162. package/dist/martyrs/src/modules/music/components/player/MusicPlayer.vue.js.map +1 -1
  163. package/dist/martyrs/src/modules/music/components/player/TrackProgress.vue.cjs +18 -15
  164. package/dist/martyrs/src/modules/music/components/player/TrackProgress.vue.cjs.map +1 -1
  165. package/dist/martyrs/src/modules/music/components/player/TrackProgress.vue.js +18 -15
  166. package/dist/martyrs/src/modules/music/components/player/TrackProgress.vue.js.map +1 -1
  167. package/dist/martyrs/src/modules/music/components/player/VolumeControl.vue.cjs +28 -23
  168. package/dist/martyrs/src/modules/music/components/player/VolumeControl.vue.cjs.map +1 -1
  169. package/dist/martyrs/src/modules/music/components/player/VolumeControl.vue.js +29 -24
  170. package/dist/martyrs/src/modules/music/components/player/VolumeControl.vue.js.map +1 -1
  171. package/dist/martyrs/src/modules/music/music.client.cjs +3 -6
  172. package/dist/martyrs/src/modules/music/music.client.cjs.map +1 -1
  173. package/dist/martyrs/src/modules/music/music.client.js +9 -12
  174. package/dist/martyrs/src/modules/music/music.client.js.map +1 -1
  175. package/dist/martyrs/src/modules/music/router/music.cjs +27 -1
  176. package/dist/martyrs/src/modules/music/router/music.cjs.map +1 -1
  177. package/dist/martyrs/src/modules/music/router/music.js +27 -1
  178. package/dist/martyrs/src/modules/music/router/music.js.map +1 -1
  179. package/dist/martyrs/src/modules/music/store/artists.cjs +6 -4
  180. package/dist/martyrs/src/modules/music/store/artists.cjs.map +1 -1
  181. package/dist/martyrs/src/modules/music/store/artists.js +6 -4
  182. package/dist/martyrs/src/modules/music/store/artists.js.map +1 -1
  183. package/dist/martyrs/src/modules/music/store/player.cjs +5 -0
  184. package/dist/martyrs/src/modules/music/store/player.cjs.map +1 -1
  185. package/dist/martyrs/src/modules/music/store/player.js +5 -0
  186. package/dist/martyrs/src/modules/music/store/player.js.map +1 -1
  187. package/dist/martyrs/src/modules/music/store/tracks.cjs +22 -0
  188. package/dist/martyrs/src/modules/music/store/tracks.cjs.map +1 -1
  189. package/dist/martyrs/src/modules/music/store/tracks.js +22 -0
  190. package/dist/martyrs/src/modules/music/store/tracks.js.map +1 -1
  191. package/dist/martyrs/src/modules/orders/components/blocks/CardOrderBackoffice.vue.js +2 -2
  192. package/dist/martyrs/src/modules/orders/components/pages/OrderBackoffice.vue.js +2 -2
  193. package/dist/martyrs/src/modules/orders/components/pages/OrderCreateBackoffice.vue.cjs +1 -1
  194. package/dist/martyrs/src/modules/orders/components/pages/OrderCreateBackoffice.vue.js +1 -1
  195. package/dist/martyrs/src/modules/orders/components/sections/FormAddCustomer.vue.cjs +1 -1
  196. package/dist/martyrs/src/modules/orders/components/sections/FormAddCustomer.vue.js +1 -1
  197. package/dist/martyrs/src/modules/orders/components/sections/FormCustomerDetails.vue.cjs +1 -1
  198. package/dist/martyrs/src/modules/orders/components/sections/FormCustomerDetails.vue.js +1 -1
  199. package/dist/martyrs/src/modules/orders/components/sections/FormDelivery.vue.cjs +1 -1
  200. package/dist/martyrs/src/modules/orders/components/sections/FormDelivery.vue.js +1 -1
  201. package/dist/martyrs/src/modules/organizations/components/blocks/CardOrganization.vue.js +2 -2
  202. package/dist/martyrs/src/modules/organizations/components/pages/DepartmentEdit.vue.cjs +1 -1
  203. package/dist/martyrs/src/modules/organizations/components/pages/DepartmentEdit.vue.js +1 -1
  204. package/dist/martyrs/src/modules/organizations/components/pages/Members.vue.cjs +1 -1
  205. package/dist/martyrs/src/modules/organizations/components/pages/Members.vue.js +1 -1
  206. package/dist/martyrs/src/modules/organizations/components/pages/Organization.vue.cjs +1 -1
  207. package/dist/martyrs/src/modules/organizations/components/pages/Organization.vue.js +1 -1
  208. package/dist/martyrs/src/modules/organizations/components/pages/OrganizationBackoffice.vue.cjs +1 -1
  209. package/dist/martyrs/src/modules/organizations/components/pages/OrganizationBackoffice.vue.js +1 -1
  210. package/dist/martyrs/src/modules/organizations/components/pages/OrganizationEdit.vue.cjs +1 -1
  211. package/dist/martyrs/src/modules/organizations/components/pages/OrganizationEdit.vue.js +1 -1
  212. package/dist/martyrs/src/modules/organizations/components/sections/Documents.vue.cjs +1 -1
  213. package/dist/martyrs/src/modules/organizations/components/sections/Documents.vue.js +1 -1
  214. package/dist/martyrs/src/modules/organizations/components/sections/MembersAdd.vue.cjs +1 -1
  215. package/dist/martyrs/src/modules/organizations/components/sections/MembersAdd.vue.js +1 -1
  216. package/dist/martyrs/src/modules/organizations/components/sections/Organizations.vue.cjs +1 -1
  217. package/dist/martyrs/src/modules/organizations/components/sections/Organizations.vue.js +1 -1
  218. package/dist/martyrs/src/modules/organizations/router/organizations.cjs +1 -1
  219. package/dist/martyrs/src/modules/organizations/router/organizations.js +1 -1
  220. package/dist/martyrs/src/modules/pages/views/components/blocks/CardPage.vue.cjs +1 -1
  221. package/dist/martyrs/src/modules/pages/views/components/blocks/CardPage.vue.js +1 -1
  222. package/dist/martyrs/src/modules/pages/views/components/pages/PageEdit.vue.cjs +1 -1
  223. package/dist/martyrs/src/modules/pages/views/components/pages/PageEdit.vue.js +1 -1
  224. package/dist/martyrs/src/modules/products/components/pages/CategoryEdit.vue.cjs +1 -1
  225. package/dist/martyrs/src/modules/products/components/pages/CategoryEdit.vue.js +1 -1
  226. package/dist/martyrs/src/modules/products/components/pages/ProductEdit.vue.cjs +1 -1
  227. package/dist/martyrs/src/modules/products/components/pages/ProductEdit.vue.js +1 -1
  228. package/dist/martyrs/src/modules/products/components/sections/EditAttributes.vue.cjs +1 -1
  229. package/dist/martyrs/src/modules/products/components/sections/EditAttributes.vue.js +1 -1
  230. package/dist/martyrs/src/modules/products/components/sections/EditDiscounts.vue.cjs +1 -1
  231. package/dist/martyrs/src/modules/products/components/sections/EditDiscounts.vue.js +1 -1
  232. package/dist/martyrs/src/modules/products/components/sections/EditVariants.vue.cjs +1 -1
  233. package/dist/martyrs/src/modules/products/components/sections/EditVariants.vue.js +1 -1
  234. package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttBar.vue.cjs +4 -3
  235. package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttBar.vue.cjs.map +1 -1
  236. package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttBar.vue.js +4 -3
  237. package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttBar.vue.js.map +1 -1
  238. package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttChart.vue.cjs +37 -70
  239. package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttChart.vue.cjs.map +1 -1
  240. package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttChart.vue.js +38 -71
  241. package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttChart.vue.js.map +1 -1
  242. package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttToolbar.vue.cjs +2 -1
  243. package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttToolbar.vue.cjs.map +1 -1
  244. package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttToolbar.vue.js +6 -5
  245. package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttToolbar.vue.js.map +1 -1
  246. package/dist/martyrs/src/modules/rents/views/components/pages/Rents.vue.cjs +45 -52
  247. package/dist/martyrs/src/modules/rents/views/components/pages/Rents.vue.cjs.map +1 -1
  248. package/dist/martyrs/src/modules/rents/views/components/pages/Rents.vue.js +46 -53
  249. package/dist/martyrs/src/modules/rents/views/components/pages/Rents.vue.js.map +1 -1
  250. package/dist/martyrs/src/modules/rents/views/components/pages/RentsEdit.vue.cjs +1 -1
  251. package/dist/martyrs/src/modules/rents/views/components/pages/RentsEdit.vue.js +1 -1
  252. package/dist/martyrs/src/modules/spots/components/blocks/SpotMemberModify.vue.cjs +1 -1
  253. package/dist/martyrs/src/modules/spots/components/blocks/SpotMemberModify.vue.js +1 -1
  254. package/dist/martyrs/src/modules/spots/components/layouts/Spots.vue.cjs +1 -1
  255. package/dist/martyrs/src/modules/spots/components/layouts/Spots.vue.js +1 -1
  256. package/dist/martyrs/src/modules/spots/components/pages/SpotEdit.vue.cjs +1 -1
  257. package/dist/martyrs/src/modules/spots/components/pages/SpotEdit.vue.js +1 -1
  258. package/dist/martyrs/src/modules/spots/components/sections/WorktimeEdit.vue.cjs +1 -1
  259. package/dist/martyrs/src/modules/spots/components/sections/WorktimeEdit.vue.js +1 -1
  260. package/dist/martyrs/src/modules/wallet/views/components/blocks/CardDeposit.vue.cjs +1 -1
  261. package/dist/martyrs/src/modules/wallet/views/components/blocks/CardDeposit.vue.js +1 -1
  262. package/dist/martyrs/src/modules/wallet/views/components/blocks/CryptoDeposit.vue.cjs +1 -1
  263. package/dist/martyrs/src/modules/wallet/views/components/blocks/CryptoDeposit.vue.js +1 -1
  264. package/dist/martyrs.cjs.js +1 -1
  265. package/dist/martyrs.css +1 -1
  266. package/dist/martyrs.es.js +1 -1
  267. package/dist/music.server.cjs +124 -31
  268. package/dist/music.server.js +124 -31
  269. package/dist/organizations.server.cjs +1 -1
  270. package/dist/organizations.server.js +1 -1
  271. package/dist/products.server.cjs +2 -2
  272. package/dist/products.server.js +2 -2
  273. package/dist/rents.server.cjs +3 -3
  274. package/dist/rents.server.js +3 -3
  275. package/dist/style.css +373 -80
  276. package/dist/{web-D7lZjuC0.js → web-Dkk0_7TA.js} +1 -1
  277. package/dist/{web-D-YZ9KHz.cjs → web-stVkXd0l.cjs} +1 -1
  278. package/package.json +1 -1
  279. package/src/builder/modes/ssr.prod.js +21 -5
  280. package/src/builder/rspack/rspack.config.spa.client.js +0 -44
  281. package/src/builder/rspack/rspack.config.ssr.client.js +40 -40
  282. package/src/components/Calendar/Calendar.vue +378 -377
  283. package/src/components/Feed/Feed.vue +28 -2
  284. package/src/modules/globals/controllers/classes/crud/crud.policies.js +5 -0
  285. package/src/modules/globals/controllers/classes/globals.validator.js +8 -1
  286. package/src/modules/globals/views/components/layouts/Client.vue +7 -0
  287. package/src/modules/music/README.md +8 -0
  288. package/src/modules/music/components/SidebarMusic.vue +6 -9
  289. package/src/modules/music/components/cards/AlbumCard.vue +20 -14
  290. package/src/modules/music/components/cards/ArtistCard.vue +1 -1
  291. package/src/modules/music/components/cards/PlaylistCard.vue +31 -11
  292. package/src/modules/music/components/cards/TrackListCard.vue +24 -13
  293. package/src/modules/music/components/forms/PlaylistForm.vue +417 -107
  294. package/src/modules/music/components/forms/SearchForm.vue +31 -8
  295. package/src/modules/music/components/forms/TrackForm.vue +50 -32
  296. package/src/modules/music/components/layouts/MusicBottomPlayer.vue +17 -0
  297. package/src/modules/music/components/pages/Album.vue +373 -186
  298. package/src/modules/music/components/pages/Artist.vue +54 -94
  299. package/src/modules/music/components/pages/MusicHome.vue +59 -56
  300. package/src/modules/music/components/pages/MusicLibrary.vue +13 -11
  301. package/src/modules/music/components/pages/Playlist.vue +495 -379
  302. package/src/modules/music/components/pages/SearchResults.vue +185 -313
  303. package/src/modules/music/components/pages/Track.vue +363 -69
  304. package/src/modules/music/components/player/MusicPlayer.vue +368 -97
  305. package/src/modules/music/components/player/TrackProgress.vue +76 -22
  306. package/src/modules/music/components/player/VolumeControl.vue +61 -28
  307. package/src/modules/music/controllers/search.controller.js +3 -0
  308. package/src/modules/music/controllers/stream.controller.js +11 -3
  309. package/src/modules/music/middlewares/playlists.verifier.js +1 -1
  310. package/src/modules/music/music.client.js +3 -6
  311. package/src/modules/music/music.server.js +8 -4
  312. package/src/modules/music/router/music.js +8 -1
  313. package/src/modules/music/routes/albums.routes.js +37 -5
  314. package/src/modules/music/routes/artists.routes.js +14 -4
  315. package/src/modules/music/routes/genres.routes.js +5 -1
  316. package/src/modules/music/routes/playlists.routes.js +42 -9
  317. package/src/modules/music/routes/tracks.routes.js +27 -2
  318. package/src/modules/music/store/artists.js +6 -2
  319. package/src/modules/music/store/player.js +6 -0
  320. package/src/modules/music/store/tracks.js +31 -0
  321. package/src/modules/music/websocket/streaming.handler.js +7 -1
  322. package/src/modules/rents/controllers/services/rents.services.js +2 -2
  323. package/src/modules/rents/views/components/pages/Gant/GanttBar.vue +4 -3
  324. package/src/modules/rents/views/components/pages/Gant/GanttChart.vue +42 -40
  325. package/src/modules/rents/views/components/pages/Gant/GanttToolbar.vue +3 -1
  326. package/src/modules/rents/views/components/pages/Rents.vue +60 -56
  327. package/dist/globals.websocket-DzvdIBf6.js +0 -306
  328. package/dist/globals.websocket-k6_B1T7k.cjs +0 -322
  329. package/dist/martyrs/src/components/Field/Field.vue2.cjs.map +0 -1
  330. package/dist/martyrs/src/components/Menu/Menu.vue.cjs.map +0 -1
  331. package/dist/martyrs/src/components/Menu/Menu.vue.js.map +0 -1
  332. package/dist/martyrs/src/modules/music/components/cards/TrackCard.vue.cjs +0 -69
  333. package/dist/martyrs/src/modules/music/components/cards/TrackCard.vue.cjs.map +0 -1
  334. package/dist/martyrs/src/modules/music/components/cards/TrackCard.vue.js +0 -69
  335. package/dist/martyrs/src/modules/music/components/cards/TrackCard.vue.js.map +0 -1
  336. package/dist/martyrs/src/modules/music/components/layouts/MusicLayout.vue.cjs +0 -104
  337. package/dist/martyrs/src/modules/music/components/layouts/MusicLayout.vue.cjs.map +0 -1
  338. package/dist/martyrs/src/modules/music/components/layouts/MusicLayout.vue.js +0 -104
  339. package/dist/martyrs/src/modules/music/components/layouts/MusicLayout.vue.js.map +0 -1
  340. package/src/modules/music/components/cards/TrackCard.vue +0 -86
  341. package/src/modules/music/components/layouts/MusicLayout.vue +0 -83
@@ -1,103 +1,105 @@
1
1
  <!-- components/player/MusicPlayer.vue -->
2
2
  <template>
3
- <div class="music-player pd-small flex-between flex-v-center flex bg-dark br-t br-solid br-dark-transp-20 ">
4
- <!-- Current Track Info -->
5
- <div class="player-track-info flex-v-center flex w-25r">
6
- <div v-if="currentTrack" class="player-track-cover mn-r-small">
7
- <Media
8
- :url="currentTrack.coverUrl || (currentTrack.album && currentTrack.album.coverUrl) || '/assets/placeholder-track.jpg'"
9
- class="w-3r h-3r object-fit-cover radius-small"
10
- />
11
- </div>
12
-
13
- <div class="player-track-details t-truncate">
14
- <div class="player-track-title t-medium t-truncate">
15
- {{ currentTrack?.title || 'No track playing' }}
3
+ <div class="player-container">
4
+ <div class="player">
5
+ <!-- Track Info Section -->
6
+ <div class="track-info">
7
+ <div class="track-image">
8
+ <Media
9
+ :url="currentTrack?.coverUrl || (currentTrack?.album && currentTrack.album.coverUrl) || '/assets/placeholder-track.jpg'"
10
+ class="track-image-media"
11
+ />
16
12
  </div>
17
- <div class="player-track-artist t-grey t-small t-truncate">
18
- {{ getArtistName(currentTrack) }}
13
+ <div class="track-details">
14
+ <h3 class="track-title">{{ currentTrack?.title || 'No track playing' }}</h3>
15
+ <p class="track-artist">{{ getArtistName(currentTrack) }}</p>
19
16
  </div>
20
- </div>
21
-
22
- <div class="player-favorite mn-l-small">
23
17
  <Button
24
18
  @click="toggleFavorite"
25
- class="bg-transparent border-none pd-zero"
19
+ class="like-btn"
20
+ :class="{ liked: isFavorite }"
26
21
  :showLoader="false"
27
22
  :showSucces="false"
28
23
  >
29
- <IconLike class="i-small" :fill="isFavorite ? 'rgb(var(--main))' : 'rgb(var(--grey))'"/>
24
+ <IconLike fill="rgb(var(--white))" class="like-icon"/>
30
25
  </Button>
31
26
  </div>
32
- </div>
33
-
34
- <!-- Player Controls -->
35
- <div class="player-controls flex-1 flex flex-column items-center">
36
- <div class="player-buttons flex-v-center flex gap-small">
37
- <Button
38
- @click="toggleShuffle"
39
- class="bg-transparent border-none pd-zero"
40
- :showLoader="false"
41
- :showSucces="false"
42
- >
43
- <IconShuffle class="i-small" :fill="shuffle ? 'rgb(var(--main))' : 'rgb(var(--grey))'"/>
44
- </Button>
45
-
46
- <Button
47
- @click="playPrevious"
48
- class="bg-transparent border-none pd-zero"
49
- :showLoader="false"
50
- :showSucces="false"
51
- >
52
- <IconPrevious class="i-small" fill="rgb(var(--white))"/>
53
- </Button>
54
-
55
- <Button
56
- @click="togglePlay"
57
- class="play-pause-btn bg-white radius-round pd-micro flex-center flex"
58
- :showLoader="false"
59
- :showSucces="false"
60
- >
61
- <IconPause v-if="isPlaying" class="i-medium" fill="rgb(var(--black))"/>
62
- <IconPlay v-else class="i-medium" fill="rgb(var(--black))"/>
63
- </Button>
27
+
28
+ <!-- Control Section -->
29
+ <div class="controls">
30
+ <div class="control-buttons">
31
+ <Button
32
+ @click="toggleShuffle"
33
+ class="control-btn secondary"
34
+ :class="{ active: shuffle }"
35
+ :showLoader="false"
36
+ :showSucces="false"
37
+ >
38
+ <IconShuffle fill="rgb(var(--white))" class="control-icon"/>
39
+ </Button>
40
+
41
+ <Button
42
+ @click="playPrevious"
43
+ class="control-btn secondary"
44
+ :showLoader="false"
45
+ :showSucces="false"
46
+ >
47
+ <IconPrevious fill="rgb(var(--white))" class="control-icon"/>
48
+ </Button>
49
+
50
+ <Button
51
+ @click="togglePlay"
52
+ class="control-btn primary"
53
+ :showLoader="false"
54
+ :showSucces="false"
55
+ >
56
+ <IconPause v-if="isPlaying" class="play-icon"/>
57
+ <IconPlay v-else class="play-icon"/>
58
+ </Button>
59
+
60
+ <Button
61
+ @click="playNext"
62
+ class="control-btn secondary"
63
+ :showLoader="false"
64
+ :showSucces="false"
65
+ >
66
+ <IconNext fill="rgb(var(--white))" class="control-icon"/>
67
+ </Button>
68
+
69
+ <Button
70
+ @click="toggleRepeat"
71
+ class="control-btn secondary"
72
+ :class="{ active: repeat !== 'off' }"
73
+ :showLoader="false"
74
+ :showSucces="false"
75
+ >
76
+ <IconRepeat fill="rgb(var(--white))" class="control-icon"/>
77
+ </Button>
78
+ </div>
64
79
 
80
+ <!-- Progress Bar -->
81
+ <div class="progress-section">
82
+ <TrackProgress />
83
+ </div>
84
+ </div>
85
+
86
+ <!-- Volume Section -->
87
+ <div class="volume-section">
65
88
  <Button
66
- @click="playNext"
67
- class="bg-transparent border-none pd-zero"
89
+ @click="toggleMute"
90
+ class="volume-btn"
68
91
  :showLoader="false"
69
92
  :showSucces="false"
70
93
  >
71
- <IconNext class="i-small" fill="rgb(var(--white))"/>
94
+ <IconVolume fill="rgb(var(--white))" v-if="!muted && volume > 0.5" class="volume-icon"/>
95
+ <IconVolumeHalf fill="rgb(var(--white))" v-else-if="!muted && volume > 0" class="volume-icon"/>
96
+ <IconVolumeMute fill="rgb(var(--white))" v-else class="volume-icon"/>
72
97
  </Button>
73
98
 
74
- <Button
75
- @click="toggleRepeat"
76
- class="bg-transparent border-none pd-zero"
77
- :showLoader="false"
78
- :showSucces="false"
79
- >
80
- <IconRepeat class="i-small" :fill="repeatIcon"/>
81
- </Button>
99
+ <div class="volume-slider">
100
+ <VolumeControl />
101
+ </div>
82
102
  </div>
83
-
84
- <TrackProgress class="w-100 mn-t-thin" />
85
- </div>
86
-
87
- <!-- Volume Control -->
88
- <div class="player-volume flex-v-center flex w-15r">
89
- <Button
90
- @click="toggleMute"
91
- class="bg-transparent border-none pd-zero mn-r-small"
92
- :showLoader="false"
93
- :showSucces="false"
94
- >
95
- <IconVolume v-if="!muted && volume > 0.5" class="i-small" fill="rgb(var(--white))"/>
96
- <IconVolumeHalf v-else-if="!muted && volume > 0" class="i-small" fill="rgb(var(--white))"/>
97
- <IconVolumeMute v-else class="i-small" fill="rgb(var(--white))"/>
98
- </Button>
99
-
100
- <VolumeControl />
101
103
  </div>
102
104
  </div>
103
105
  </template>
@@ -118,7 +120,7 @@ import IconShuffle from '@martyrs/src/modules/icons/navigation/IconShuffle.vue';
118
120
  import IconRepeat from '@martyrs/src/modules/icons/navigation/IconRefresh.vue';
119
121
  import IconLike from '@martyrs/src/modules/icons/navigation/IconLike.vue';
120
122
  import IconVolume from '@martyrs/src/modules/icons/navigation/IconVolume.vue';
121
- // import IconVolumeHalf from '@martyrs/src/modules/icons/navigation/IconVolume.vue'; // Using same icon but we'd style it differently
123
+ import IconVolumeHalf from '@martyrs/src/modules/icons/navigation/IconVolume.vue';
122
124
  import IconVolumeMute from '@martyrs/src/modules/icons/navigation/IconMute.vue';
123
125
 
124
126
  // Import player store
@@ -135,17 +137,6 @@ const muted = computed(() => playerState.muted);
135
137
  const shuffle = computed(() => playerState.shuffle);
136
138
  const repeat = computed(() => playerState.repeat);
137
139
 
138
- const repeatIcon = computed(() => {
139
- switch(repeat.value) {
140
- case 'one':
141
- return 'rgb(var(--main))';
142
- case 'all':
143
- return 'rgb(var(--main))';
144
- default:
145
- return 'rgb(var(--grey))';
146
- }
147
- });
148
-
149
140
  // Methods
150
141
  const togglePlay = () => {
151
142
  playerActions.togglePlay();
@@ -190,13 +181,293 @@ const getArtistName = (track) => {
190
181
  </script>
191
182
 
192
183
  <style scoped>
193
- .play-pause-btn {
184
+ .player-container {
185
+ bottom: 0;
186
+ left: 0;
187
+ right: 0;
188
+ z-index: 1000;
189
+ background: linear-gradient(135deg, rgb(24, 24, 24) 0%, rgb(18, 18, 18) 100%);
190
+ border-top: 1px solid rgb(40, 40, 40);
191
+ backdrop-filter: blur(10px);
192
+ }
193
+
194
+ .player {
195
+ display: grid;
196
+ grid-template-columns: 1fr 2fr 1fr;
197
+ align-items: center;
198
+ padding: 12px 16px;
199
+ gap: 16px;
200
+ height: 90px;
201
+ max-width: 100%;
202
+ }
203
+
204
+ /* Track Info Section */
205
+ .track-info {
206
+ display: flex;
207
+ align-items: center;
208
+ gap: 12px;
209
+ min-width: 0;
210
+ }
211
+
212
+ .track-image {
213
+ width: 56px;
214
+ height: 56px;
215
+ border-radius: 4px;
216
+ overflow: hidden;
217
+ flex-shrink: 0;
218
+ }
219
+
220
+ .track-image-media {
221
+ width: 100%;
222
+ height: 100%;
223
+ object-fit: cover;
224
+ transition: transform 0.3s ease;
225
+ }
226
+
227
+ .track-image:hover .track-image-media {
228
+ transform: scale(1.05);
229
+ }
230
+
231
+ .track-details {
232
+ min-width: 0;
233
+ flex: 1;
234
+ }
235
+
236
+ .track-title {
237
+ font-size: 14px;
238
+ font-weight: 600;
239
+ color: rgb(var(--white));
240
+ margin: 0;
241
+ white-space: nowrap;
242
+ overflow: hidden;
243
+ text-overflow: ellipsis;
244
+ line-height: 1.2;
245
+ }
246
+
247
+ .track-artist {
248
+ font-size: 12px;
249
+ color: rgb(var(--grey));
250
+ margin: 2px 0 0 0;
251
+ white-space: nowrap;
252
+ overflow: hidden;
253
+ text-overflow: ellipsis;
254
+ }
255
+
256
+ .like-btn {
257
+ background: none;
258
+ border: none;
259
+ color: rgb(var(--grey));
260
+ cursor: pointer;
261
+ padding: 8px;
262
+ border-radius: 50%;
263
+ transition: all 0.2s ease;
264
+ display: flex;
265
+ align-items: center;
266
+ justify-content: center;
267
+ }
268
+
269
+ .like-icon {
270
+ width: 16px;
271
+ height: 16px;
272
+ }
273
+
274
+ .like-btn:hover {
275
+ color: rgb(var(--white));
276
+ background: rgba(255, 255, 255, 0.1);
277
+ }
278
+
279
+ .like-btn.liked {
280
+ color: rgb(var(--main));
281
+ }
282
+
283
+ .like-btn.liked .like-icon {
284
+ fill: rgb(var(--main));
285
+ }
286
+
287
+ .like-btn.liked:hover {
288
+ color: rgb(var(--main));
289
+ opacity: 0.8;
290
+ }
291
+
292
+ /* Controls Section */
293
+ .controls {
294
+ display: flex;
295
+ flex-direction: column;
296
+ align-items: center;
297
+ gap: 8px;
298
+ width: 100%;
299
+ }
300
+
301
+ .control-buttons {
302
+ display: flex;
303
+ align-items: center;
304
+ gap: 16px;
305
+ }
306
+
307
+ .control-btn {
308
+ background: none;
309
+ border: none;
310
+ color: rgb(var(--grey));
311
+ cursor: pointer;
312
+ padding: 8px;
313
+ border-radius: 50%;
314
+ transition: all 0.2s ease;
315
+ display: flex;
316
+ align-items: center;
317
+ justify-content: center;
318
+ }
319
+
320
+ .control-icon {
321
+ width: 16px;
322
+ height: 16px;
323
+ }
324
+
325
+ .control-btn.primary {
326
+ background: rgb(var(--white));
327
+ color: rgb(var(--black));
194
328
  width: 32px;
195
329
  height: 32px;
196
- transition: transform 0.2s ease;
197
330
  }
198
331
 
199
- .play-pause-btn:hover {
200
- transform: scale(1.1);
332
+ .play-icon {
333
+ width: 14px;
334
+ height: 14px;
335
+ fill: rgb(var(--black));
336
+ }
337
+
338
+ .control-btn.primary:hover {
339
+ background: rgb(240, 240, 240);
340
+ transform: scale(1.06);
341
+ }
342
+
343
+ .control-btn.secondary:hover {
344
+ color: rgb(var(--white));
345
+ background: rgba(255, 255, 255, 0.1);
346
+ }
347
+
348
+ .control-btn.secondary:hover .control-icon {
349
+ fill: rgb(var(--white));
350
+ }
351
+
352
+ .control-btn.active {
353
+ color: rgb(var(--main));
354
+ }
355
+
356
+ .control-btn.active .control-icon {
357
+ fill: rgb(var(--main));
358
+ }
359
+
360
+ .control-btn.active:hover {
361
+ color: rgb(var(--main));
362
+ opacity: 0.8;
363
+ }
364
+
365
+ /* Progress Section */
366
+ .progress-section {
367
+ width: 100%;
368
+ max-width: 600px;
369
+ }
370
+
371
+ /* Volume Section */
372
+ .volume-section {
373
+ display: flex;
374
+ align-items: center;
375
+ gap: 12px;
376
+ justify-content: flex-end;
377
+ }
378
+
379
+ .volume-btn {
380
+ background: none;
381
+ border: none;
382
+ color: rgb(var(--grey));
383
+ cursor: pointer;
384
+ padding: 8px;
385
+ border-radius: 50%;
386
+ transition: all 0.2s ease;
387
+ display: flex;
388
+ align-items: center;
389
+ justify-content: center;
390
+ }
391
+
392
+ .volume-icon {
393
+ width: 16px;
394
+ height: 16px;
395
+ }
396
+
397
+ .volume-btn:hover {
398
+ color: rgb(var(--white));
399
+ background: rgba(255, 255, 255, 0.1);
400
+ }
401
+
402
+ .volume-btn:hover .volume-icon {
403
+ fill: rgb(var(--white));
404
+ }
405
+
406
+ .volume-slider {
407
+ width: 100px;
408
+ }
409
+
410
+ /* Responsive Design */
411
+ @media (max-width: 768px) {
412
+ .player {
413
+ grid-template-columns: 1fr;
414
+ grid-template-rows: auto auto auto;
415
+ height: auto;
416
+ padding: 8px 12px 12px;
417
+ gap: 12px;
418
+ }
419
+
420
+ .track-info {
421
+ order: 1;
422
+ }
423
+
424
+ .controls {
425
+ order: 2;
426
+ }
427
+
428
+ .volume-section {
429
+ order: 3;
430
+ justify-content: center;
431
+ }
432
+
433
+ .volume-slider {
434
+ width: 120px;
435
+ }
436
+
437
+ .progress-section {
438
+ max-width: 100%;
439
+ }
440
+ }
441
+
442
+ /* Animations */
443
+ @keyframes fadeIn {
444
+ from {
445
+ opacity: 0;
446
+ transform: translateY(20px);
447
+ }
448
+ to {
449
+ opacity: 1;
450
+ transform: translateY(0);
451
+ }
452
+ }
453
+
454
+ .player-container {
455
+ animation: fadeIn 0.3s ease-out;
456
+ }
457
+
458
+ @keyframes pulse {
459
+ 0% {
460
+ transform: scale(1);
461
+ }
462
+ 50% {
463
+ transform: scale(1.05);
464
+ }
465
+ 100% {
466
+ transform: scale(1);
467
+ }
468
+ }
469
+
470
+ .control-btn.primary:active {
471
+ animation: pulse 0.3s ease;
201
472
  }
202
473
  </style>
@@ -1,33 +1,33 @@
1
1
  <!-- components/player/TrackProgress.vue -->
2
2
  <template>
3
- <div class="track-progress flex flex-v-center gap-small">
4
- <div class="current-time t-grey t-small">{{ formatTime(currentTime) }}</div>
5
-
3
+ <div class="progress-section">
4
+ <span class="time-current">{{ formatTime(currentTime) }}</span>
6
5
  <div
7
6
  ref="progressBarContainer"
8
- class="progress-bar-container flex-1 h-thin bg-grey radius-extra pos-relative cursor-pointer"
7
+ class="progress-bar"
9
8
  @click="seek"
10
9
  @mousedown="startSeek"
11
10
  @mousemove="updateSeekPosition"
12
11
  @mouseup="endSeek"
13
12
  @mouseleave="endSeek"
14
13
  >
15
- <div
16
- class="progress-bar h-100 bg-white radius-extra"
17
- :style="{ width: progressPercentage + '%' }"
18
- ></div>
19
- <div
20
- class="progress-handle w-thin h-thin bg-white radius-round pos-absolute pos-t-50 pos-l-0"
21
- :style="{ left: `calc(${progressPercentage}% - 4px)`, transform: 'translateY(-50%)' }"
22
- ></div>
14
+ <div class="progress-track">
15
+ <div
16
+ class="progress-fill"
17
+ :style="{ width: progressPercentage + '%' }"
18
+ ></div>
19
+ <div
20
+ class="progress-thumb"
21
+ :style="{ left: progressPercentage + '%' }"
22
+ ></div>
23
+ </div>
23
24
  </div>
24
-
25
- <div class="total-time t-grey t-small">{{ formatTime(duration) }}</div>
25
+ <span class="time-total">{{ formatTime(duration) }}</span>
26
26
  </div>
27
27
  </template>
28
28
 
29
29
  <script setup>
30
- import { ref, computed, onMounted, onUnmounted } from 'vue';
30
+ import { ref, computed, onUnmounted } from 'vue';
31
31
 
32
32
  // Import player store
33
33
  import { state as playerState, actions as playerActions } from '../../store/player.js';
@@ -95,16 +95,70 @@ onUnmounted(() => {
95
95
  </script>
96
96
 
97
97
  <style scoped>
98
- .progress-bar-container:hover .progress-bar {
99
- background-color: rgb(var(--main));
98
+ /* Progress Section */
99
+ .progress-section {
100
+ display: flex;
101
+ align-items: center;
102
+ gap: 12px;
103
+ width: 100%;
100
104
  }
101
105
 
102
- .progress-handle {
103
- display: none;
106
+ .time-current,
107
+ .time-total {
108
+ font-size: 11px;
109
+ color: rgb(var(--grey));
110
+ font-weight: 400;
111
+ min-width: 32px;
112
+ text-align: center;
104
113
  }
105
114
 
106
- .progress-bar-container:hover .progress-handle {
107
- display: block;
108
- transform: translateY(-50%) scale(1.3);
115
+ .progress-bar {
116
+ flex: 1;
117
+ height: 12px;
118
+ display: flex;
119
+ align-items: center;
120
+ cursor: pointer;
121
+ padding: 4px 0;
122
+ }
123
+
124
+ .progress-track {
125
+ position: relative;
126
+ width: 100%;
127
+ height: 4px;
128
+ background: rgb(79, 79, 79);
129
+ border-radius: 2px;
130
+ overflow: hidden;
131
+ transition: height 0.2s ease;
132
+ }
133
+
134
+ .progress-fill {
135
+ height: 100%;
136
+ background: rgb(var(--white));
137
+ border-radius: 2px;
138
+ transition: width 0.1s ease;
139
+ }
140
+
141
+ .progress-thumb {
142
+ position: absolute;
143
+ top: 50%;
144
+ width: 12px;
145
+ height: 12px;
146
+ background: rgb(var(--white));
147
+ border-radius: 50%;
148
+ transform: translate(-50%, -50%);
149
+ opacity: 0;
150
+ transition: opacity 0.2s ease;
151
+ }
152
+
153
+ .progress-bar:hover .progress-thumb {
154
+ opacity: 1;
155
+ }
156
+
157
+ .progress-bar:hover .progress-track {
158
+ height: 6px;
159
+ }
160
+
161
+ .progress-bar:hover .progress-fill {
162
+ background: rgb(var(--main));
109
163
  }
110
164
  </style>