@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.
- package/dist/_virtual/index.cjs +4 -4
- package/dist/_virtual/index.js +4 -4
- package/dist/_virtual/index2.cjs +4 -4
- package/dist/_virtual/index2.js +4 -4
- package/dist/builder.cjs +53 -90
- package/dist/builder.js +54 -91
- package/dist/{crud-B-kQw3Z5.cjs → crud-JN_LFj01.cjs} +3 -0
- package/dist/{crud-Cwx5VlSm.js → crud-sE7GLPbj.js} +3 -0
- package/dist/globals.server.cjs +322 -3
- package/dist/globals.server.js +303 -1
- package/dist/{globals.verifier-D68mHEBl.cjs → globals.verifier-C0zj_LLo.cjs} +8 -1
- package/dist/{globals.verifier-CWFz5Gh2.js → globals.verifier-DFqKQ7hK.js} +8 -1
- package/dist/inventory.server.cjs +2 -2
- package/dist/inventory.server.js +2 -2
- package/dist/{main-SZQ1QjeP.js → main-CJm5myDI.js} +631 -607
- package/dist/{main-MzmGbSxs.cjs → main-DTaE01lg.cjs} +6 -6
- package/dist/martyrs/src/components/Calendar/Calendar.vue2.cjs +1 -1
- package/dist/martyrs/src/components/Calendar/Calendar.vue2.cjs.map +1 -1
- package/dist/martyrs/src/components/Calendar/Calendar.vue2.js +1 -1
- package/dist/martyrs/src/components/Calendar/Calendar.vue2.js.map +1 -1
- package/dist/martyrs/src/components/Feed/Feed.vue.cjs +33 -7
- package/dist/martyrs/src/components/Feed/Feed.vue.cjs.map +1 -1
- package/dist/martyrs/src/components/Feed/Feed.vue.js +33 -7
- package/dist/martyrs/src/components/Feed/Feed.vue.js.map +1 -1
- package/dist/martyrs/src/components/Field/{Field.vue2.cjs → Field.vue.cjs} +2 -2
- package/dist/martyrs/src/components/Field/{Field.vue2.js.map → Field.vue.cjs.map} +1 -1
- package/dist/martyrs/src/components/Field/{Field.vue2.js → Field.vue.js} +2 -2
- package/dist/martyrs/src/components/Field/Field.vue.js.map +1 -0
- package/dist/martyrs/src/components/FieldBig/FieldBig.vue.cjs +1 -1
- package/dist/martyrs/src/components/FieldBig/FieldBig.vue.js +1 -1
- package/dist/martyrs/src/components/FieldTags/FieldTags.vue.cjs +1 -1
- package/dist/martyrs/src/components/FieldTags/FieldTags.vue.js +1 -1
- package/dist/martyrs/src/components/Menu/{Menu.vue.cjs → Menu.vue2.cjs} +2 -2
- package/dist/martyrs/src/components/Menu/Menu.vue2.cjs.map +1 -0
- package/dist/martyrs/src/components/Menu/{Menu.vue.js → Menu.vue2.js} +2 -2
- package/dist/martyrs/src/components/Menu/Menu.vue2.js.map +1 -0
- package/dist/martyrs/src/components/Menu/MenuItem.vue.js +2 -2
- package/dist/martyrs/src/components/Menu/MenuItem.vue.js.map +1 -1
- package/dist/martyrs/src/components/PhotoViewer/PhotoViewer.vue.js +4 -4
- package/dist/martyrs/src/modules/auth/views/components/pages/EnterCode.vue.cjs +1 -1
- package/dist/martyrs/src/modules/auth/views/components/pages/EnterCode.vue.js +1 -1
- package/dist/martyrs/src/modules/auth/views/components/pages/EnterPassword.vue.cjs +1 -1
- package/dist/martyrs/src/modules/auth/views/components/pages/EnterPassword.vue.js +1 -1
- package/dist/martyrs/src/modules/auth/views/components/pages/Invite.vue.cjs +1 -1
- package/dist/martyrs/src/modules/auth/views/components/pages/Invite.vue.js +1 -1
- package/dist/martyrs/src/modules/auth/views/components/pages/Profile.vue.cjs +2 -2
- package/dist/martyrs/src/modules/auth/views/components/pages/Profile.vue.js +2 -2
- package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditProfile.vue.cjs +1 -1
- package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditProfile.vue.js +1 -1
- package/dist/martyrs/src/modules/auth/views/components/pages/ResetPassword.vue.cjs +1 -1
- package/dist/martyrs/src/modules/auth/views/components/pages/ResetPassword.vue.js +1 -1
- package/dist/martyrs/src/modules/auth/views/components/pages/SignIn.vue.cjs +1 -1
- package/dist/martyrs/src/modules/auth/views/components/pages/SignIn.vue.js +1 -1
- package/dist/martyrs/src/modules/auth/views/components/pages/SignUp.vue.cjs +1 -1
- package/dist/martyrs/src/modules/auth/views/components/pages/SignUp.vue.js +1 -1
- package/dist/martyrs/src/modules/auth/views/components/sections/ProfileEditCredentials.vue.cjs +1 -1
- package/dist/martyrs/src/modules/auth/views/components/sections/ProfileEditCredentials.vue.js +1 -1
- package/dist/martyrs/src/modules/community/components/pages/CreateBlogPost.vue.cjs +2 -2
- package/dist/martyrs/src/modules/community/components/pages/CreateBlogPost.vue.js +2 -2
- package/dist/martyrs/src/modules/constructor/components/elements/Card.vue.cjs +1 -1
- package/dist/martyrs/src/modules/constructor/components/elements/Card.vue.js +1 -1
- package/dist/martyrs/src/modules/constructor/components/elements/Embed.vue.cjs +1 -1
- package/dist/martyrs/src/modules/constructor/components/elements/Embed.vue.js +1 -1
- package/dist/martyrs/src/modules/events/components/pages/EditEvent.vue.cjs +1 -1
- package/dist/martyrs/src/modules/events/components/pages/EditEvent.vue.js +1 -1
- package/dist/martyrs/src/modules/events/components/pages/EditEventTickets.vue.cjs +1 -1
- package/dist/martyrs/src/modules/events/components/pages/EditEventTickets.vue.js +1 -1
- package/dist/martyrs/src/modules/events/components/pages/Event.vue.cjs +1 -1
- package/dist/martyrs/src/modules/events/components/pages/Event.vue.js +1 -1
- package/dist/martyrs/src/modules/gallery/components/sections/BackofficeGallery.vue.cjs +1 -1
- package/dist/martyrs/src/modules/gallery/components/sections/BackofficeGallery.vue.js +1 -1
- package/dist/martyrs/src/modules/globals/views/classes/globals.i18n.cjs +1 -1
- package/dist/martyrs/src/modules/globals/views/classes/globals.i18n.js +1 -1
- package/dist/martyrs/src/modules/globals/views/components/blocks/BlockSearch.vue.cjs +1 -1
- package/dist/martyrs/src/modules/globals/views/components/blocks/BlockSearch.vue.js +1 -1
- package/dist/martyrs/src/modules/globals/views/components/layouts/Client.vue.cjs +5 -1
- package/dist/martyrs/src/modules/globals/views/components/layouts/Client.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/globals/views/components/layouts/Client.vue.js +5 -1
- package/dist/martyrs/src/modules/globals/views/components/layouts/Client.vue.js.map +1 -1
- package/dist/martyrs/src/modules/icons/entities/IconTime.vue.cjs +2 -2
- package/dist/martyrs/src/modules/icons/entities/IconTime.vue.js +2 -2
- package/dist/martyrs/src/modules/icons/navigation/IconChevronLeft.vue.cjs +2 -2
- package/dist/martyrs/src/modules/icons/navigation/IconChevronLeft.vue.js +2 -2
- package/dist/martyrs/src/modules/icons/navigation/IconChevronRight.vue.cjs +2 -2
- package/dist/martyrs/src/modules/icons/navigation/IconChevronRight.vue.js +2 -2
- package/dist/martyrs/src/modules/icons/pages/IconsPage.vue.js +6 -6
- package/dist/martyrs/src/modules/icons/pages/IconsPage.vue.js.map +1 -1
- package/dist/martyrs/src/modules/inventory/components/forms/AdjustmentForm.vue.cjs +1 -1
- package/dist/martyrs/src/modules/inventory/components/forms/AdjustmentForm.vue.js +1 -1
- package/dist/martyrs/src/modules/inventory/components/forms/StockAlertsForm.vue.cjs +1 -1
- package/dist/martyrs/src/modules/inventory/components/forms/StockAlertsForm.vue.js +1 -1
- package/dist/martyrs/src/modules/inventory/components/pages/Inventory.vue.cjs +1 -1
- package/dist/martyrs/src/modules/inventory/components/pages/InventoryEdit.vue.cjs +1 -1
- package/dist/martyrs/src/modules/inventory/components/pages/InventoryEdit.vue.js +1 -1
- package/dist/martyrs/src/modules/music/components/cards/AlbumCard.vue.cjs +22 -15
- package/dist/martyrs/src/modules/music/components/cards/AlbumCard.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/music/components/cards/AlbumCard.vue.js +23 -16
- package/dist/martyrs/src/modules/music/components/cards/AlbumCard.vue.js.map +1 -1
- package/dist/martyrs/src/modules/music/components/cards/ArtistCard.vue.cjs +2 -2
- package/dist/martyrs/src/modules/music/components/cards/ArtistCard.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/music/components/cards/ArtistCard.vue.js +2 -2
- package/dist/martyrs/src/modules/music/components/cards/ArtistCard.vue.js.map +1 -1
- package/dist/martyrs/src/modules/music/components/cards/PlaylistCard.vue.cjs +31 -13
- package/dist/martyrs/src/modules/music/components/cards/PlaylistCard.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/music/components/cards/PlaylistCard.vue.js +33 -15
- package/dist/martyrs/src/modules/music/components/cards/PlaylistCard.vue.js.map +1 -1
- package/dist/martyrs/src/modules/music/components/cards/TrackListCard.vue.cjs +39 -22
- package/dist/martyrs/src/modules/music/components/cards/TrackListCard.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/music/components/cards/TrackListCard.vue.js +39 -22
- package/dist/martyrs/src/modules/music/components/cards/TrackListCard.vue.js.map +1 -1
- package/dist/martyrs/src/modules/music/components/forms/AlbumForm.vue.cjs +1 -1
- package/dist/martyrs/src/modules/music/components/forms/AlbumForm.vue.js +1 -1
- package/dist/martyrs/src/modules/music/components/forms/ArtistForm.vue.cjs +1 -1
- package/dist/martyrs/src/modules/music/components/forms/ArtistForm.vue.js +1 -1
- package/dist/martyrs/src/modules/music/components/forms/PlaylistForm.vue.cjs +385 -125
- package/dist/martyrs/src/modules/music/components/forms/PlaylistForm.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/music/components/forms/PlaylistForm.vue.js +391 -131
- package/dist/martyrs/src/modules/music/components/forms/PlaylistForm.vue.js.map +1 -1
- package/dist/martyrs/src/modules/music/components/forms/SearchForm.vue.cjs +24 -7
- package/dist/martyrs/src/modules/music/components/forms/SearchForm.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/music/components/forms/SearchForm.vue.js +25 -8
- package/dist/martyrs/src/modules/music/components/forms/SearchForm.vue.js.map +1 -1
- package/dist/martyrs/src/modules/music/components/forms/TrackForm.vue.cjs +99 -87
- package/dist/martyrs/src/modules/music/components/forms/TrackForm.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/music/components/forms/TrackForm.vue.js +111 -99
- package/dist/martyrs/src/modules/music/components/forms/TrackForm.vue.js.map +1 -1
- package/dist/martyrs/src/modules/music/components/layouts/MusicBottomPlayer.vue.cjs +21 -0
- package/dist/martyrs/src/modules/music/components/layouts/MusicBottomPlayer.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/layouts/MusicBottomPlayer.vue.js +21 -0
- package/dist/martyrs/src/modules/music/components/layouts/MusicBottomPlayer.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/Album.vue.cjs +442 -210
- package/dist/martyrs/src/modules/music/components/pages/Album.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/music/components/pages/Album.vue.js +445 -213
- package/dist/martyrs/src/modules/music/components/pages/Album.vue.js.map +1 -1
- package/dist/martyrs/src/modules/music/components/pages/Artist.vue.cjs +92 -117
- package/dist/martyrs/src/modules/music/components/pages/Artist.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/music/components/pages/Artist.vue.js +93 -118
- package/dist/martyrs/src/modules/music/components/pages/Artist.vue.js.map +1 -1
- package/dist/martyrs/src/modules/music/components/pages/MusicHome.vue.cjs +72 -113
- package/dist/martyrs/src/modules/music/components/pages/MusicHome.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/music/components/pages/MusicHome.vue.js +78 -119
- package/dist/martyrs/src/modules/music/components/pages/MusicHome.vue.js.map +1 -1
- package/dist/martyrs/src/modules/music/components/pages/MusicLibrary.vue.cjs +15 -12
- package/dist/martyrs/src/modules/music/components/pages/MusicLibrary.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/music/components/pages/MusicLibrary.vue.js +15 -12
- package/dist/martyrs/src/modules/music/components/pages/MusicLibrary.vue.js.map +1 -1
- package/dist/martyrs/src/modules/music/components/pages/Playlist.vue.cjs +558 -429
- package/dist/martyrs/src/modules/music/components/pages/Playlist.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/music/components/pages/Playlist.vue.js +560 -431
- package/dist/martyrs/src/modules/music/components/pages/Playlist.vue.js.map +1 -1
- package/dist/martyrs/src/modules/music/components/pages/SearchResults.vue.cjs +146 -284
- package/dist/martyrs/src/modules/music/components/pages/SearchResults.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/music/components/pages/SearchResults.vue.js +149 -287
- package/dist/martyrs/src/modules/music/components/pages/SearchResults.vue.js.map +1 -1
- package/dist/martyrs/src/modules/music/components/pages/Track.vue.cjs +460 -63
- package/dist/martyrs/src/modules/music/components/pages/Track.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/music/components/pages/Track.vue.js +462 -65
- package/dist/martyrs/src/modules/music/components/pages/Track.vue.js.map +1 -1
- package/dist/martyrs/src/modules/music/components/player/MusicPlayer.vue.cjs +126 -136
- package/dist/martyrs/src/modules/music/components/player/MusicPlayer.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/music/components/player/MusicPlayer.vue.js +129 -139
- package/dist/martyrs/src/modules/music/components/player/MusicPlayer.vue.js.map +1 -1
- package/dist/martyrs/src/modules/music/components/player/TrackProgress.vue.cjs +18 -15
- package/dist/martyrs/src/modules/music/components/player/TrackProgress.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/music/components/player/TrackProgress.vue.js +18 -15
- package/dist/martyrs/src/modules/music/components/player/TrackProgress.vue.js.map +1 -1
- package/dist/martyrs/src/modules/music/components/player/VolumeControl.vue.cjs +28 -23
- package/dist/martyrs/src/modules/music/components/player/VolumeControl.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/music/components/player/VolumeControl.vue.js +29 -24
- package/dist/martyrs/src/modules/music/components/player/VolumeControl.vue.js.map +1 -1
- package/dist/martyrs/src/modules/music/music.client.cjs +3 -6
- package/dist/martyrs/src/modules/music/music.client.cjs.map +1 -1
- package/dist/martyrs/src/modules/music/music.client.js +9 -12
- package/dist/martyrs/src/modules/music/music.client.js.map +1 -1
- package/dist/martyrs/src/modules/music/router/music.cjs +27 -1
- package/dist/martyrs/src/modules/music/router/music.cjs.map +1 -1
- package/dist/martyrs/src/modules/music/router/music.js +27 -1
- package/dist/martyrs/src/modules/music/router/music.js.map +1 -1
- package/dist/martyrs/src/modules/music/store/artists.cjs +6 -4
- package/dist/martyrs/src/modules/music/store/artists.cjs.map +1 -1
- package/dist/martyrs/src/modules/music/store/artists.js +6 -4
- package/dist/martyrs/src/modules/music/store/artists.js.map +1 -1
- package/dist/martyrs/src/modules/music/store/player.cjs +5 -0
- package/dist/martyrs/src/modules/music/store/player.cjs.map +1 -1
- package/dist/martyrs/src/modules/music/store/player.js +5 -0
- package/dist/martyrs/src/modules/music/store/player.js.map +1 -1
- package/dist/martyrs/src/modules/music/store/tracks.cjs +22 -0
- package/dist/martyrs/src/modules/music/store/tracks.cjs.map +1 -1
- package/dist/martyrs/src/modules/music/store/tracks.js +22 -0
- package/dist/martyrs/src/modules/music/store/tracks.js.map +1 -1
- package/dist/martyrs/src/modules/orders/components/blocks/CardOrderBackoffice.vue.js +2 -2
- package/dist/martyrs/src/modules/orders/components/pages/OrderBackoffice.vue.js +2 -2
- package/dist/martyrs/src/modules/orders/components/pages/OrderCreateBackoffice.vue.cjs +1 -1
- package/dist/martyrs/src/modules/orders/components/pages/OrderCreateBackoffice.vue.js +1 -1
- package/dist/martyrs/src/modules/orders/components/sections/FormAddCustomer.vue.cjs +1 -1
- package/dist/martyrs/src/modules/orders/components/sections/FormAddCustomer.vue.js +1 -1
- package/dist/martyrs/src/modules/orders/components/sections/FormCustomerDetails.vue.cjs +1 -1
- package/dist/martyrs/src/modules/orders/components/sections/FormCustomerDetails.vue.js +1 -1
- package/dist/martyrs/src/modules/orders/components/sections/FormDelivery.vue.cjs +1 -1
- package/dist/martyrs/src/modules/orders/components/sections/FormDelivery.vue.js +1 -1
- package/dist/martyrs/src/modules/organizations/components/blocks/CardOrganization.vue.js +2 -2
- package/dist/martyrs/src/modules/organizations/components/pages/DepartmentEdit.vue.cjs +1 -1
- package/dist/martyrs/src/modules/organizations/components/pages/DepartmentEdit.vue.js +1 -1
- package/dist/martyrs/src/modules/organizations/components/pages/Members.vue.cjs +1 -1
- package/dist/martyrs/src/modules/organizations/components/pages/Members.vue.js +1 -1
- package/dist/martyrs/src/modules/organizations/components/pages/Organization.vue.cjs +1 -1
- package/dist/martyrs/src/modules/organizations/components/pages/Organization.vue.js +1 -1
- package/dist/martyrs/src/modules/organizations/components/pages/OrganizationBackoffice.vue.cjs +1 -1
- package/dist/martyrs/src/modules/organizations/components/pages/OrganizationBackoffice.vue.js +1 -1
- package/dist/martyrs/src/modules/organizations/components/pages/OrganizationEdit.vue.cjs +1 -1
- package/dist/martyrs/src/modules/organizations/components/pages/OrganizationEdit.vue.js +1 -1
- package/dist/martyrs/src/modules/organizations/components/sections/Documents.vue.cjs +1 -1
- package/dist/martyrs/src/modules/organizations/components/sections/Documents.vue.js +1 -1
- package/dist/martyrs/src/modules/organizations/components/sections/MembersAdd.vue.cjs +1 -1
- package/dist/martyrs/src/modules/organizations/components/sections/MembersAdd.vue.js +1 -1
- package/dist/martyrs/src/modules/organizations/components/sections/Organizations.vue.cjs +1 -1
- package/dist/martyrs/src/modules/organizations/components/sections/Organizations.vue.js +1 -1
- package/dist/martyrs/src/modules/organizations/router/organizations.cjs +1 -1
- package/dist/martyrs/src/modules/organizations/router/organizations.js +1 -1
- package/dist/martyrs/src/modules/pages/views/components/blocks/CardPage.vue.cjs +1 -1
- package/dist/martyrs/src/modules/pages/views/components/blocks/CardPage.vue.js +1 -1
- package/dist/martyrs/src/modules/pages/views/components/pages/PageEdit.vue.cjs +1 -1
- package/dist/martyrs/src/modules/pages/views/components/pages/PageEdit.vue.js +1 -1
- package/dist/martyrs/src/modules/products/components/pages/CategoryEdit.vue.cjs +1 -1
- package/dist/martyrs/src/modules/products/components/pages/CategoryEdit.vue.js +1 -1
- package/dist/martyrs/src/modules/products/components/pages/ProductEdit.vue.cjs +1 -1
- package/dist/martyrs/src/modules/products/components/pages/ProductEdit.vue.js +1 -1
- package/dist/martyrs/src/modules/products/components/sections/EditAttributes.vue.cjs +1 -1
- package/dist/martyrs/src/modules/products/components/sections/EditAttributes.vue.js +1 -1
- package/dist/martyrs/src/modules/products/components/sections/EditDiscounts.vue.cjs +1 -1
- package/dist/martyrs/src/modules/products/components/sections/EditDiscounts.vue.js +1 -1
- package/dist/martyrs/src/modules/products/components/sections/EditVariants.vue.cjs +1 -1
- package/dist/martyrs/src/modules/products/components/sections/EditVariants.vue.js +1 -1
- package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttBar.vue.cjs +4 -3
- package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttBar.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttBar.vue.js +4 -3
- package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttBar.vue.js.map +1 -1
- package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttChart.vue.cjs +37 -70
- package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttChart.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttChart.vue.js +38 -71
- package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttChart.vue.js.map +1 -1
- package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttToolbar.vue.cjs +2 -1
- package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttToolbar.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttToolbar.vue.js +6 -5
- package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttToolbar.vue.js.map +1 -1
- package/dist/martyrs/src/modules/rents/views/components/pages/Rents.vue.cjs +45 -52
- package/dist/martyrs/src/modules/rents/views/components/pages/Rents.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/rents/views/components/pages/Rents.vue.js +46 -53
- package/dist/martyrs/src/modules/rents/views/components/pages/Rents.vue.js.map +1 -1
- package/dist/martyrs/src/modules/rents/views/components/pages/RentsEdit.vue.cjs +1 -1
- package/dist/martyrs/src/modules/rents/views/components/pages/RentsEdit.vue.js +1 -1
- package/dist/martyrs/src/modules/spots/components/blocks/SpotMemberModify.vue.cjs +1 -1
- package/dist/martyrs/src/modules/spots/components/blocks/SpotMemberModify.vue.js +1 -1
- package/dist/martyrs/src/modules/spots/components/layouts/Spots.vue.cjs +1 -1
- package/dist/martyrs/src/modules/spots/components/layouts/Spots.vue.js +1 -1
- package/dist/martyrs/src/modules/spots/components/pages/SpotEdit.vue.cjs +1 -1
- package/dist/martyrs/src/modules/spots/components/pages/SpotEdit.vue.js +1 -1
- package/dist/martyrs/src/modules/spots/components/sections/WorktimeEdit.vue.cjs +1 -1
- package/dist/martyrs/src/modules/spots/components/sections/WorktimeEdit.vue.js +1 -1
- package/dist/martyrs/src/modules/wallet/views/components/blocks/CardDeposit.vue.cjs +1 -1
- package/dist/martyrs/src/modules/wallet/views/components/blocks/CardDeposit.vue.js +1 -1
- package/dist/martyrs/src/modules/wallet/views/components/blocks/CryptoDeposit.vue.cjs +1 -1
- package/dist/martyrs/src/modules/wallet/views/components/blocks/CryptoDeposit.vue.js +1 -1
- package/dist/martyrs.cjs.js +1 -1
- package/dist/martyrs.css +1 -1
- package/dist/martyrs.es.js +1 -1
- package/dist/music.server.cjs +124 -31
- package/dist/music.server.js +124 -31
- package/dist/organizations.server.cjs +1 -1
- package/dist/organizations.server.js +1 -1
- package/dist/products.server.cjs +2 -2
- package/dist/products.server.js +2 -2
- package/dist/rents.server.cjs +3 -3
- package/dist/rents.server.js +3 -3
- package/dist/style.css +373 -80
- package/dist/{web-D7lZjuC0.js → web-Dkk0_7TA.js} +1 -1
- package/dist/{web-D-YZ9KHz.cjs → web-stVkXd0l.cjs} +1 -1
- package/package.json +1 -1
- package/src/builder/modes/ssr.prod.js +21 -5
- package/src/builder/rspack/rspack.config.spa.client.js +0 -44
- package/src/builder/rspack/rspack.config.ssr.client.js +40 -40
- package/src/components/Calendar/Calendar.vue +378 -377
- package/src/components/Feed/Feed.vue +28 -2
- package/src/modules/globals/controllers/classes/crud/crud.policies.js +5 -0
- package/src/modules/globals/controllers/classes/globals.validator.js +8 -1
- package/src/modules/globals/views/components/layouts/Client.vue +7 -0
- package/src/modules/music/README.md +8 -0
- package/src/modules/music/components/SidebarMusic.vue +6 -9
- package/src/modules/music/components/cards/AlbumCard.vue +20 -14
- package/src/modules/music/components/cards/ArtistCard.vue +1 -1
- package/src/modules/music/components/cards/PlaylistCard.vue +31 -11
- package/src/modules/music/components/cards/TrackListCard.vue +24 -13
- package/src/modules/music/components/forms/PlaylistForm.vue +417 -107
- package/src/modules/music/components/forms/SearchForm.vue +31 -8
- package/src/modules/music/components/forms/TrackForm.vue +50 -32
- package/src/modules/music/components/layouts/MusicBottomPlayer.vue +17 -0
- package/src/modules/music/components/pages/Album.vue +373 -186
- package/src/modules/music/components/pages/Artist.vue +54 -94
- package/src/modules/music/components/pages/MusicHome.vue +59 -56
- package/src/modules/music/components/pages/MusicLibrary.vue +13 -11
- package/src/modules/music/components/pages/Playlist.vue +495 -379
- package/src/modules/music/components/pages/SearchResults.vue +185 -313
- package/src/modules/music/components/pages/Track.vue +363 -69
- package/src/modules/music/components/player/MusicPlayer.vue +368 -97
- package/src/modules/music/components/player/TrackProgress.vue +76 -22
- package/src/modules/music/components/player/VolumeControl.vue +61 -28
- package/src/modules/music/controllers/search.controller.js +3 -0
- package/src/modules/music/controllers/stream.controller.js +11 -3
- package/src/modules/music/middlewares/playlists.verifier.js +1 -1
- package/src/modules/music/music.client.js +3 -6
- package/src/modules/music/music.server.js +8 -4
- package/src/modules/music/router/music.js +8 -1
- package/src/modules/music/routes/albums.routes.js +37 -5
- package/src/modules/music/routes/artists.routes.js +14 -4
- package/src/modules/music/routes/genres.routes.js +5 -1
- package/src/modules/music/routes/playlists.routes.js +42 -9
- package/src/modules/music/routes/tracks.routes.js +27 -2
- package/src/modules/music/store/artists.js +6 -2
- package/src/modules/music/store/player.js +6 -0
- package/src/modules/music/store/tracks.js +31 -0
- package/src/modules/music/websocket/streaming.handler.js +7 -1
- package/src/modules/rents/controllers/services/rents.services.js +2 -2
- package/src/modules/rents/views/components/pages/Gant/GanttBar.vue +4 -3
- package/src/modules/rents/views/components/pages/Gant/GanttChart.vue +42 -40
- package/src/modules/rents/views/components/pages/Gant/GanttToolbar.vue +3 -1
- package/src/modules/rents/views/components/pages/Rents.vue +60 -56
- package/dist/globals.websocket-DzvdIBf6.js +0 -306
- package/dist/globals.websocket-k6_B1T7k.cjs +0 -322
- package/dist/martyrs/src/components/Field/Field.vue2.cjs.map +0 -1
- package/dist/martyrs/src/components/Menu/Menu.vue.cjs.map +0 -1
- package/dist/martyrs/src/components/Menu/Menu.vue.js.map +0 -1
- package/dist/martyrs/src/modules/music/components/cards/TrackCard.vue.cjs +0 -69
- package/dist/martyrs/src/modules/music/components/cards/TrackCard.vue.cjs.map +0 -1
- package/dist/martyrs/src/modules/music/components/cards/TrackCard.vue.js +0 -69
- package/dist/martyrs/src/modules/music/components/cards/TrackCard.vue.js.map +0 -1
- package/dist/martyrs/src/modules/music/components/layouts/MusicLayout.vue.cjs +0 -104
- package/dist/martyrs/src/modules/music/components/layouts/MusicLayout.vue.cjs.map +0 -1
- package/dist/martyrs/src/modules/music/components/layouts/MusicLayout.vue.js +0 -104
- package/dist/martyrs/src/modules/music/components/layouts/MusicLayout.vue.js.map +0 -1
- package/src/modules/music/components/cards/TrackCard.vue +0 -86
- 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="
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
<div
|
|
7
|
-
<
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
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="
|
|
18
|
-
{{
|
|
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="
|
|
19
|
+
class="like-btn"
|
|
20
|
+
:class="{ liked: isFavorite }"
|
|
26
21
|
:showLoader="false"
|
|
27
22
|
:showSucces="false"
|
|
28
23
|
>
|
|
29
|
-
<IconLike
|
|
24
|
+
<IconLike fill="rgb(var(--white))" class="like-icon"/>
|
|
30
25
|
</Button>
|
|
31
26
|
</div>
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
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="
|
|
67
|
-
class="
|
|
89
|
+
@click="toggleMute"
|
|
90
|
+
class="volume-btn"
|
|
68
91
|
:showLoader="false"
|
|
69
92
|
:showSucces="false"
|
|
70
93
|
>
|
|
71
|
-
<
|
|
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
|
-
<
|
|
75
|
-
|
|
76
|
-
|
|
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
|
-
|
|
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
|
-
.
|
|
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-
|
|
200
|
-
|
|
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="
|
|
4
|
-
<
|
|
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
|
|
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
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
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,
|
|
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
|
-
|
|
99
|
-
|
|
98
|
+
/* Progress Section */
|
|
99
|
+
.progress-section {
|
|
100
|
+
display: flex;
|
|
101
|
+
align-items: center;
|
|
102
|
+
gap: 12px;
|
|
103
|
+
width: 100%;
|
|
100
104
|
}
|
|
101
105
|
|
|
102
|
-
.
|
|
103
|
-
|
|
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
|
|
107
|
-
|
|
108
|
-
|
|
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>
|