@ozdao/martyrs 0.2.485 → 0.2.486
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/{Media-DlUBwVWs.js → Media-CXQSPHt2.js} +1 -1
- package/dist/{Media-ByPHBvAU.cjs → Media-DhpD64nT.cjs} +1 -1
- 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/auth.server.cjs +2 -23
- package/dist/auth.server.js +1 -22
- package/dist/globals.crud-BQG1Lm0A.js +90 -0
- package/dist/globals.crud-Dv7UXbRM.cjs +89 -0
- package/dist/globals.server.cjs +3 -322
- package/dist/globals.server.js +1 -303
- package/dist/globals.websocket-DzvdIBf6.js +306 -0
- package/dist/globals.websocket-k6_B1T7k.cjs +322 -0
- package/dist/{main-CK6rC5Sz.js → main-Cfh5138F.js} +2155 -2087
- package/dist/main-DKJqboZy.cjs +11 -0
- package/dist/martyrs/src/components/Button/{Button.vue2.cjs → Button.vue.cjs} +2 -2
- package/dist/martyrs/src/components/Button/{Button.vue2.js.map → Button.vue.cjs.map} +1 -1
- package/dist/martyrs/src/components/Button/{Button.vue2.js → Button.vue.js} +2 -2
- package/dist/martyrs/src/components/Button/Button.vue.js.map +1 -0
- package/dist/martyrs/src/components/{DatePicker → Calendar}/Calendar.vue.cjs +1 -1
- package/dist/martyrs/src/components/Calendar/Calendar.vue.cjs.map +1 -0
- package/dist/martyrs/src/components/{DatePicker → Calendar}/Calendar.vue.js +1 -1
- package/dist/martyrs/src/components/Calendar/Calendar.vue.js.map +1 -0
- package/dist/martyrs/src/components/Feed/Feed.vue.cjs +1 -1
- package/dist/martyrs/src/components/Feed/Feed.vue.cjs.map +1 -1
- package/dist/martyrs/src/components/Feed/Feed.vue.js +1 -1
- package/dist/martyrs/src/components/Feed/Feed.vue.js.map +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.vue2.cjs → Menu.vue.cjs} +2 -2
- package/dist/martyrs/src/components/Menu/Menu.vue.cjs.map +1 -0
- package/dist/martyrs/src/components/Menu/{Menu.vue2.js → Menu.vue.js} +2 -2
- package/dist/martyrs/src/components/Menu/Menu.vue.js.map +1 -0
- package/dist/martyrs/src/components/Popup/{Popup.vue2.cjs → Popup.vue.cjs} +2 -2
- package/dist/martyrs/src/components/Popup/{Popup.vue2.js.map → Popup.vue.cjs.map} +1 -1
- package/dist/martyrs/src/components/Popup/{Popup.vue2.js → Popup.vue.js} +2 -2
- package/dist/martyrs/src/components/Popup/Popup.vue.js.map +1 -0
- 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/ProfileEdit.vue.cjs +1 -1
- package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEdit.vue.js +1 -1
- package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditAccount.vue.cjs +1 -1
- package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditAccount.vue.js +1 -1
- 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/BlogPost.vue.cjs +2 -2
- package/dist/martyrs/src/modules/community/components/pages/BlogPost.vue.js +2 -2
- package/dist/martyrs/src/modules/community/components/pages/CreateBlogPost.vue.cjs +3 -3
- package/dist/martyrs/src/modules/community/components/pages/CreateBlogPost.vue.js +3 -3
- package/dist/martyrs/src/modules/events/components/elements/ButtonCheck.vue.cjs +1 -1
- package/dist/martyrs/src/modules/events/components/elements/ButtonCheck.vue.js +1 -1
- package/dist/martyrs/src/modules/events/components/elements/ButtonJoin.vue.cjs +1 -1
- package/dist/martyrs/src/modules/events/components/elements/ButtonJoin.vue.js +1 -1
- package/dist/martyrs/src/modules/events/components/pages/EditEvent.vue.cjs +2 -2
- package/dist/martyrs/src/modules/events/components/pages/EditEvent.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/events/components/pages/EditEvent.vue.js +2 -2
- package/dist/martyrs/src/modules/events/components/pages/EditEvent.vue.js.map +1 -1
- package/dist/martyrs/src/modules/events/components/pages/EditEventTickets.vue.cjs +2 -2
- package/dist/martyrs/src/modules/events/components/pages/EditEventTickets.vue.js +2 -2
- package/dist/martyrs/src/modules/events/components/pages/Events.vue.cjs +1 -1
- package/dist/martyrs/src/modules/events/components/pages/Events.vue.js +1 -1
- package/dist/martyrs/src/modules/gallery/components/pages/Gallery.vue.cjs +1 -1
- package/dist/martyrs/src/modules/gallery/components/pages/Gallery.vue.js +1 -1
- package/dist/martyrs/src/modules/gallery/components/sections/BackofficeGallery.vue.cjs +2 -2
- package/dist/martyrs/src/modules/gallery/components/sections/BackofficeGallery.vue.js +2 -2
- 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/AlertDialog.vue.cjs +1 -1
- package/dist/martyrs/src/modules/globals/views/components/blocks/AlertDialog.vue.js +1 -1
- package/dist/martyrs/src/modules/globals/views/components/blocks/CardHeader.vue.cjs +1 -1
- package/dist/martyrs/src/modules/globals/views/components/blocks/CardHeader.vue.js +1 -1
- package/dist/martyrs/src/modules/globals/views/components/blocks/PopupAuth.vue.cjs +2 -2
- package/dist/martyrs/src/modules/globals/views/components/blocks/PopupAuth.vue.js +2 -2
- package/dist/martyrs/src/modules/globals/views/components/blocks/PopupDateSelector.vue.cjs +3 -3
- package/dist/martyrs/src/modules/globals/views/components/blocks/PopupDateSelector.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/globals/views/components/blocks/PopupDateSelector.vue.js +3 -3
- package/dist/martyrs/src/modules/globals/views/components/blocks/PopupDateSelector.vue.js.map +1 -1
- package/dist/martyrs/src/modules/globals/views/components/layouts/Client.vue.cjs +2 -2
- package/dist/martyrs/src/modules/globals/views/components/layouts/Client.vue.js +2 -2
- package/dist/martyrs/src/modules/globals/views/components/partials/Header.vue.cjs +1 -1
- package/dist/martyrs/src/modules/globals/views/components/partials/Header.vue.js +1 -1
- package/dist/martyrs/src/modules/globals/views/components/partials/NavigationBar.vue.cjs +1 -1
- package/dist/martyrs/src/modules/globals/views/components/partials/NavigationBar.vue.js +1 -1
- package/dist/martyrs/src/modules/globals/views/components/sections/Filters.vue2.cjs +1 -1
- package/dist/martyrs/src/modules/globals/views/components/sections/Filters.vue2.js +1 -1
- package/dist/martyrs/src/modules/globals/views/utils/axios-instance.cjs.map +1 -1
- package/dist/martyrs/src/modules/globals/views/utils/axios-instance.js.map +1 -1
- package/dist/martyrs/src/modules/music/components/cards/AlbumCard.vue.cjs +87 -0
- package/dist/martyrs/src/modules/music/components/cards/AlbumCard.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/cards/AlbumCard.vue.js +87 -0
- package/dist/martyrs/src/modules/music/components/cards/AlbumCard.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/cards/ArtistCard.vue.cjs +83 -0
- package/dist/martyrs/src/modules/music/components/cards/ArtistCard.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/cards/ArtistCard.vue.js +83 -0
- package/dist/martyrs/src/modules/music/components/cards/ArtistCard.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/cards/PlaylistCard.vue.cjs +83 -0
- package/dist/martyrs/src/modules/music/components/cards/PlaylistCard.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/cards/PlaylistCard.vue.js +83 -0
- package/dist/martyrs/src/modules/music/components/cards/PlaylistCard.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/cards/TrackCard.vue.cjs +68 -0
- package/dist/martyrs/src/modules/music/components/cards/TrackCard.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/cards/TrackCard.vue.js +68 -0
- package/dist/martyrs/src/modules/music/components/cards/TrackCard.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/forms/PlaylistForm.vue.cjs +174 -0
- package/dist/martyrs/src/modules/music/components/forms/PlaylistForm.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/forms/PlaylistForm.vue.js +174 -0
- package/dist/martyrs/src/modules/music/components/forms/PlaylistForm.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/forms/SearchForm.vue.cjs +80 -0
- package/dist/martyrs/src/modules/music/components/forms/SearchForm.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/forms/SearchForm.vue.js +80 -0
- package/dist/martyrs/src/modules/music/components/forms/SearchForm.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/forms/UploadForm.vue.cjs +328 -0
- package/dist/martyrs/src/modules/music/components/forms/UploadForm.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/forms/UploadForm.vue.js +328 -0
- package/dist/martyrs/src/modules/music/components/forms/UploadForm.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/layouts/MusicLayout.vue.cjs +115 -0
- package/dist/martyrs/src/modules/music/components/layouts/MusicLayout.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/layouts/MusicLayout.vue.js +115 -0
- package/dist/martyrs/src/modules/music/components/layouts/MusicLayout.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/lists/AlbumList.vue.cjs +44 -0
- package/dist/martyrs/src/modules/music/components/lists/AlbumList.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/lists/AlbumList.vue.js +44 -0
- package/dist/martyrs/src/modules/music/components/lists/AlbumList.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/lists/ArtistList.vue.cjs +305 -0
- package/dist/martyrs/src/modules/music/components/lists/ArtistList.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/lists/ArtistList.vue.js +305 -0
- package/dist/martyrs/src/modules/music/components/lists/ArtistList.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/lists/PlaylistList.vue.cjs +44 -0
- package/dist/martyrs/src/modules/music/components/lists/PlaylistList.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/lists/PlaylistList.vue.js +44 -0
- package/dist/martyrs/src/modules/music/components/lists/PlaylistList.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/lists/TrackList.vue.cjs +199 -0
- package/dist/martyrs/src/modules/music/components/lists/TrackList.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/lists/TrackList.vue.js +199 -0
- package/dist/martyrs/src/modules/music/components/lists/TrackList.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/AlbumDetail.vue.cjs +290 -0
- package/dist/martyrs/src/modules/music/components/pages/AlbumDetail.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/AlbumDetail.vue.js +290 -0
- package/dist/martyrs/src/modules/music/components/pages/AlbumDetail.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/ArtistDetail.vue.cjs +467 -0
- package/dist/martyrs/src/modules/music/components/pages/ArtistDetail.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/ArtistDetail.vue.js +467 -0
- package/dist/martyrs/src/modules/music/components/pages/ArtistDetail.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/ArtistForm.vue.cjs +382 -0
- package/dist/martyrs/src/modules/music/components/pages/ArtistForm.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/ArtistForm.vue.js +382 -0
- package/dist/martyrs/src/modules/music/components/pages/ArtistForm.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/ArtistManager.vue.cjs +303 -0
- package/dist/martyrs/src/modules/music/components/pages/ArtistManager.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/ArtistManager.vue.js +303 -0
- package/dist/martyrs/src/modules/music/components/pages/ArtistManager.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/MusicHome.vue.cjs +221 -0
- package/dist/martyrs/src/modules/music/components/pages/MusicHome.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/MusicHome.vue.js +221 -0
- package/dist/martyrs/src/modules/music/components/pages/MusicHome.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/MusicLibrary.vue.cjs +200 -0
- package/dist/martyrs/src/modules/music/components/pages/MusicLibrary.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/MusicLibrary.vue.js +200 -0
- package/dist/martyrs/src/modules/music/components/pages/MusicLibrary.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/MusicUpload.vue.cjs +50 -0
- package/dist/martyrs/src/modules/music/components/pages/MusicUpload.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/MusicUpload.vue.js +50 -0
- package/dist/martyrs/src/modules/music/components/pages/MusicUpload.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/PlaylistDetail.vue.cjs +556 -0
- package/dist/martyrs/src/modules/music/components/pages/PlaylistDetail.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/PlaylistDetail.vue.js +556 -0
- package/dist/martyrs/src/modules/music/components/pages/PlaylistDetail.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/SearchResults.vue.cjs +449 -0
- package/dist/martyrs/src/modules/music/components/pages/SearchResults.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/SearchResults.vue.js +449 -0
- package/dist/martyrs/src/modules/music/components/pages/SearchResults.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/TrackDetail.vue.cjs +87 -0
- package/dist/martyrs/src/modules/music/components/pages/TrackDetail.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/TrackDetail.vue.js +87 -0
- package/dist/martyrs/src/modules/music/components/pages/TrackDetail.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/player/MusicPlayer.vue.cjs +227 -0
- package/dist/martyrs/src/modules/music/components/player/MusicPlayer.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/player/MusicPlayer.vue.js +227 -0
- package/dist/martyrs/src/modules/music/components/player/MusicPlayer.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/player/TrackProgress.vue.cjs +85 -0
- package/dist/martyrs/src/modules/music/components/player/TrackProgress.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/player/TrackProgress.vue.js +85 -0
- package/dist/martyrs/src/modules/music/components/player/TrackProgress.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/player/VolumeControl.vue.cjs +71 -0
- package/dist/martyrs/src/modules/music/components/player/VolumeControl.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/player/VolumeControl.vue.js +71 -0
- package/dist/martyrs/src/modules/music/components/player/VolumeControl.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/music.client.cjs +137 -0
- package/dist/martyrs/src/modules/music/music.client.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/music.client.js +137 -0
- package/dist/martyrs/src/modules/music/music.client.js.map +1 -0
- package/dist/martyrs/src/modules/music/router/music.cjs +99 -0
- package/dist/martyrs/src/modules/music/router/music.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/router/music.js +99 -0
- package/dist/martyrs/src/modules/music/router/music.js.map +1 -0
- package/dist/martyrs/src/modules/music/store/albums.cjs +167 -0
- package/dist/martyrs/src/modules/music/store/albums.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/store/albums.js +167 -0
- package/dist/martyrs/src/modules/music/store/albums.js.map +1 -0
- package/dist/martyrs/src/modules/music/store/artists.cjs +154 -0
- package/dist/martyrs/src/modules/music/store/artists.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/store/artists.js +154 -0
- package/dist/martyrs/src/modules/music/store/artists.js.map +1 -0
- package/dist/martyrs/src/modules/music/store/player.cjs +297 -0
- package/dist/martyrs/src/modules/music/store/player.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/store/player.js +297 -0
- package/dist/martyrs/src/modules/music/store/player.js.map +1 -0
- package/dist/martyrs/src/modules/music/store/playlists.cjs +174 -0
- package/dist/martyrs/src/modules/music/store/playlists.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/store/playlists.js +174 -0
- package/dist/martyrs/src/modules/music/store/playlists.js.map +1 -0
- package/dist/martyrs/src/modules/music/store/search.cjs +109 -0
- package/dist/martyrs/src/modules/music/store/search.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/store/search.js +109 -0
- package/dist/martyrs/src/modules/music/store/search.js.map +1 -0
- package/dist/martyrs/src/modules/music/store/tracks.cjs +180 -0
- package/dist/martyrs/src/modules/music/store/tracks.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/store/tracks.js +180 -0
- package/dist/martyrs/src/modules/music/store/tracks.js.map +1 -0
- package/dist/martyrs/src/modules/notifications/components/elements/NotificationBadge.vue.cjs +1 -1
- package/dist/martyrs/src/modules/notifications/components/elements/NotificationBadge.vue.js +1 -1
- package/dist/martyrs/src/modules/orders/components/pages/OrderBackoffice.vue.cjs +2 -2
- package/dist/martyrs/src/modules/orders/components/pages/OrderBackoffice.vue.js +2 -2
- package/dist/martyrs/src/modules/orders/components/pages/OrderCreate.vue.cjs +1 -1
- package/dist/martyrs/src/modules/orders/components/pages/OrderCreate.vue.js +1 -1
- package/dist/martyrs/src/modules/orders/components/pages/OrderCreateBackoffice.vue.cjs +2 -2
- package/dist/martyrs/src/modules/orders/components/pages/OrderCreateBackoffice.vue.js +2 -2
- 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/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/elements/ButtonToggleMembership.vue.cjs +1 -1
- package/dist/martyrs/src/modules/organizations/components/elements/ButtonToggleMembership.vue.js +1 -1
- package/dist/martyrs/src/modules/organizations/components/pages/DepartmentEdit.vue.cjs +2 -2
- package/dist/martyrs/src/modules/organizations/components/pages/DepartmentEdit.vue.js +2 -2
- package/dist/martyrs/src/modules/organizations/components/pages/Members.vue.cjs +2 -2
- package/dist/martyrs/src/modules/organizations/components/pages/Members.vue.js +2 -2
- 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 +2 -2
- package/dist/martyrs/src/modules/organizations/components/pages/OrganizationEdit.vue.js +2 -2
- package/dist/martyrs/src/modules/organizations/components/sections/Documents.vue.cjs +2 -2
- package/dist/martyrs/src/modules/organizations/components/sections/Documents.vue.js +2 -2
- 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/pages/views/components/partials/SidebarPages.vue.cjs +2 -2
- package/dist/martyrs/src/modules/pages/views/components/partials/SidebarPages.vue.js +2 -2
- package/dist/martyrs/src/modules/products/components/blocks/ProductImages.vue.cjs +1 -1
- package/dist/martyrs/src/modules/products/components/blocks/ProductImages.vue.js +1 -1
- package/dist/martyrs/src/modules/products/components/pages/Categories.vue.cjs +1 -1
- package/dist/martyrs/src/modules/products/components/pages/Categories.vue.js +1 -1
- package/dist/martyrs/src/modules/products/components/pages/CategoryEdit.vue.cjs +2 -2
- package/dist/martyrs/src/modules/products/components/pages/CategoryEdit.vue.js +2 -2
- package/dist/martyrs/src/modules/products/components/pages/LeftoverEdit.vue.cjs +2 -2
- package/dist/martyrs/src/modules/products/components/pages/LeftoverEdit.vue.js +2 -2
- package/dist/martyrs/src/modules/products/components/pages/Leftovers.vue.cjs +2 -2
- package/dist/martyrs/src/modules/products/components/pages/Leftovers.vue.js +1 -1
- package/dist/martyrs/src/modules/products/components/pages/Product.vue.cjs +2 -2
- package/dist/martyrs/src/modules/products/components/pages/Product.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/products/components/pages/Product.vue.js +2 -2
- package/dist/martyrs/src/modules/products/components/pages/Product.vue.js.map +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 +2 -2
- package/dist/martyrs/src/modules/products/components/sections/EditAttributes.vue.js +2 -2
- package/dist/martyrs/src/modules/products/components/sections/EditDiscounts.vue.cjs +2 -2
- package/dist/martyrs/src/modules/products/components/sections/EditDiscounts.vue.js +2 -2
- package/dist/martyrs/src/modules/products/components/sections/EditIngredients.vue.cjs +1 -1
- package/dist/martyrs/src/modules/products/components/sections/EditIngredients.vue.js +1 -1
- package/dist/martyrs/src/modules/products/components/sections/EditRecommended.vue.cjs +1 -1
- package/dist/martyrs/src/modules/products/components/sections/EditRecommended.vue.js +1 -1
- package/dist/martyrs/src/modules/products/components/sections/EditVariants.vue.cjs +2 -2
- package/dist/martyrs/src/modules/products/components/sections/EditVariants.vue.js +2 -2
- package/dist/martyrs/src/modules/products/components/sections/ProductConfigurator.vue.cjs +1 -1
- package/dist/martyrs/src/modules/products/components/sections/ProductConfigurator.vue.js +1 -1
- package/dist/martyrs/src/modules/products/components/sections/ProductsRecommended.vue.cjs +1 -1
- package/dist/martyrs/src/modules/products/components/sections/ProductsRecommended.vue.js +1 -1
- package/dist/martyrs/src/modules/products/components/sections/SectionProduct.vue.cjs +1 -1
- package/dist/martyrs/src/modules/products/components/sections/SectionProduct.vue.js +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/reports/components/sections/FormReport.vue.cjs +2 -2
- package/dist/martyrs/src/modules/reports/components/sections/FormReport.vue.js +2 -2
- package/dist/martyrs/src/modules/spots/components/pages/Map.vue.cjs +1 -1
- package/dist/martyrs/src/modules/spots/components/pages/Map.vue.js +1 -1
- package/dist/martyrs/src/modules/spots/components/pages/SpotEdit.vue.cjs +2 -2
- package/dist/martyrs/src/modules/spots/components/pages/SpotEdit.vue.js +2 -2
- package/dist/martyrs/src/modules/spots/components/sections/WorktimeEdit.vue.cjs +2 -2
- package/dist/martyrs/src/modules/spots/components/sections/WorktimeEdit.vue.js +2 -2
- package/dist/martyrs/src/modules/wallet/views/components/pages/Wallet.vue.cjs +2 -2
- package/dist/martyrs/src/modules/wallet/views/components/pages/Wallet.vue.js +2 -2
- package/dist/martyrs.cjs.js +1 -1
- package/dist/martyrs.css +1 -1
- package/dist/martyrs.es.js +38 -36
- package/dist/music.server.cjs +1407 -0
- package/dist/music.server.js +1407 -0
- package/dist/node_modules/.pnpm/qrcode@1.5.4/node_modules/qrcode/lib/core/utils.cjs +1 -1
- package/dist/node_modules/.pnpm/qrcode@1.5.4/node_modules/qrcode/lib/core/utils.js +1 -1
- package/dist/node_modules/.pnpm/qrcode@1.5.4/node_modules/qrcode/lib/renderer/utils.cjs +1 -1
- package/dist/node_modules/.pnpm/qrcode@1.5.4/node_modules/qrcode/lib/renderer/utils.js +1 -1
- package/dist/orders.server.cjs +3 -88
- package/dist/orders.server.js +2 -87
- package/dist/socials.schema-BOZV82Mp.js +25 -0
- package/dist/socials.schema-CtpSF9dE.cjs +24 -0
- package/dist/style.css +155 -15
- package/package.json +1 -1
- package/src/.martyrs/filemap.json +2 -2
- package/src/components/Feed/Feed.vue +1 -1
- package/src/components/index.js +2 -0
- package/src/main.js +6 -0
- package/src/modules/events/components/pages/EditEvent.vue +1 -1
- package/src/modules/globals/views/components/blocks/PopupDateSelector.vue +1 -1
- package/src/modules/globals/views/utils/axios-instance.js +15 -1
- package/src/modules/products/components/pages/Product.vue +1 -1
- package/dist/main-137vO86w.cjs +0 -11
- package/dist/martyrs/src/components/Button/Button.vue2.cjs.map +0 -1
- package/dist/martyrs/src/components/DatePicker/Calendar.vue.cjs.map +0 -1
- package/dist/martyrs/src/components/DatePicker/Calendar.vue.js.map +0 -1
- package/dist/martyrs/src/components/Menu/Menu.vue2.cjs.map +0 -1
- package/dist/martyrs/src/components/Menu/Menu.vue2.js.map +0 -1
- package/dist/martyrs/src/components/Popup/Popup.vue2.cjs.map +0 -1
- /package/src/components/{DatePicker → Calendar}/Calendar.vue +0 -0
|
@@ -0,0 +1,199 @@
|
|
|
1
|
+
import { ref, computed, resolveComponent, createElementBlock, openBlock, createCommentVNode, createElementVNode, Fragment, renderList, normalizeClass, createBlock, toDisplayString, withModifiers, withCtx, createVNode, createTextVNode } from "vue";
|
|
2
|
+
import Media from "../../../../components/Media/Media.vue.js";
|
|
3
|
+
import _sfc_main$1 from "../../../../components/Button/Button.vue.js";
|
|
4
|
+
import _sfc_main$2 from "../../../icons/navigation/IconPlay.vue.js";
|
|
5
|
+
import _sfc_main$3 from "../../../icons/navigation/IconPause.vue.js";
|
|
6
|
+
import { state, actions } from "../../store/player.js";
|
|
7
|
+
import _export_sfc from "../../../../../../_virtual/_plugin-vue_export-helper.js";
|
|
8
|
+
const _hoisted_1 = { class: "track-list w-100" };
|
|
9
|
+
const _hoisted_2 = {
|
|
10
|
+
key: 0,
|
|
11
|
+
class: "track-list-header pd-small br-b br-solid br-dark-transp-20 t-grey flex-v-center flex"
|
|
12
|
+
};
|
|
13
|
+
const _hoisted_3 = {
|
|
14
|
+
key: 0,
|
|
15
|
+
class: "track-album w-15r mobile:w-0 mobile:hidden"
|
|
16
|
+
};
|
|
17
|
+
const _hoisted_4 = { class: "track-list-body" };
|
|
18
|
+
const _hoisted_5 = ["onClick", "onDblclick", "onMouseenter"];
|
|
19
|
+
const _hoisted_6 = { class: "track-number w-3r t-center pos-relative" };
|
|
20
|
+
const _hoisted_7 = {
|
|
21
|
+
key: 0,
|
|
22
|
+
class: "t-grey"
|
|
23
|
+
};
|
|
24
|
+
const _hoisted_8 = { class: "track-title flex-child-1 flex flex-v-center" };
|
|
25
|
+
const _hoisted_9 = {
|
|
26
|
+
key: 0,
|
|
27
|
+
class: "track-cover mn-r-small"
|
|
28
|
+
};
|
|
29
|
+
const _hoisted_10 = { class: "track-info" };
|
|
30
|
+
const _hoisted_11 = { class: "track-artist t-grey t-small" };
|
|
31
|
+
const _hoisted_12 = { key: 1 };
|
|
32
|
+
const _hoisted_13 = {
|
|
33
|
+
key: 0,
|
|
34
|
+
class: "track-album w-15r mobile:w-0 mobile:hidden t-grey t-truncate"
|
|
35
|
+
};
|
|
36
|
+
const _hoisted_14 = { key: 1 };
|
|
37
|
+
const _hoisted_15 = { class: "track-duration w-5r t-right t-grey" };
|
|
38
|
+
const _sfc_main = {
|
|
39
|
+
__name: "TrackList",
|
|
40
|
+
props: {
|
|
41
|
+
tracks: {
|
|
42
|
+
type: Array,
|
|
43
|
+
required: true
|
|
44
|
+
},
|
|
45
|
+
showHeader: {
|
|
46
|
+
type: Boolean,
|
|
47
|
+
default: true
|
|
48
|
+
},
|
|
49
|
+
showAlbum: {
|
|
50
|
+
type: Boolean,
|
|
51
|
+
default: false
|
|
52
|
+
},
|
|
53
|
+
showCover: {
|
|
54
|
+
type: Boolean,
|
|
55
|
+
default: false
|
|
56
|
+
},
|
|
57
|
+
showIndex: {
|
|
58
|
+
type: Boolean,
|
|
59
|
+
default: true
|
|
60
|
+
}
|
|
61
|
+
},
|
|
62
|
+
setup(__props) {
|
|
63
|
+
const props = __props;
|
|
64
|
+
const hoveredIndex = ref(-1);
|
|
65
|
+
const currentTrack = computed(() => state.currentTrack);
|
|
66
|
+
const isPlaying = (track) => {
|
|
67
|
+
return currentTrack.value && currentTrack.value._id === track._id && isPlaying.value;
|
|
68
|
+
};
|
|
69
|
+
const playTrack = (track, addToQueue = false) => {
|
|
70
|
+
if (addToQueue) {
|
|
71
|
+
actions.addToQueue(track);
|
|
72
|
+
} else {
|
|
73
|
+
const trackIndex = props.tracks.findIndex((t) => t._id === track._id);
|
|
74
|
+
actions.setQueue([...props.tracks], trackIndex);
|
|
75
|
+
}
|
|
76
|
+
};
|
|
77
|
+
const pauseTrack = () => {
|
|
78
|
+
actions.togglePlay();
|
|
79
|
+
};
|
|
80
|
+
const getArtistName = (track) => {
|
|
81
|
+
if (track.artist) {
|
|
82
|
+
if (typeof track.artist === "object") {
|
|
83
|
+
return track.artist.name || "Unknown Artist";
|
|
84
|
+
}
|
|
85
|
+
return track.artist;
|
|
86
|
+
}
|
|
87
|
+
return "Unknown Artist";
|
|
88
|
+
};
|
|
89
|
+
const formatDuration = (seconds) => {
|
|
90
|
+
if (!seconds) return "0:00";
|
|
91
|
+
const minutes = Math.floor(seconds / 60);
|
|
92
|
+
const remainingSeconds = Math.floor(seconds % 60);
|
|
93
|
+
return `${minutes}:${remainingSeconds.toString().padStart(2, "0")}`;
|
|
94
|
+
};
|
|
95
|
+
return (_ctx, _cache) => {
|
|
96
|
+
const _component_router_link = resolveComponent("router-link");
|
|
97
|
+
return openBlock(), createElementBlock("div", _hoisted_1, [
|
|
98
|
+
__props.showHeader ? (openBlock(), createElementBlock("div", _hoisted_2, [
|
|
99
|
+
_cache[4] || (_cache[4] = createElementVNode("div", { class: "track-number w-3r t-center" }, "#", -1)),
|
|
100
|
+
_cache[5] || (_cache[5] = createElementVNode("div", { class: "track-title flex-child-1" }, "TITLE", -1)),
|
|
101
|
+
__props.showAlbum ? (openBlock(), createElementBlock("div", _hoisted_3, "ALBUM")) : createCommentVNode("", true),
|
|
102
|
+
_cache[6] || (_cache[6] = createElementVNode("div", { class: "track-duration w-5r t-right" }, "DURATION", -1))
|
|
103
|
+
])) : createCommentVNode("", true),
|
|
104
|
+
createElementVNode("div", _hoisted_4, [
|
|
105
|
+
(openBlock(true), createElementBlock(Fragment, null, renderList(__props.tracks, (track, index) => {
|
|
106
|
+
var _a;
|
|
107
|
+
return openBlock(), createElementBlock("div", {
|
|
108
|
+
key: track._id,
|
|
109
|
+
class: normalizeClass(["track-item pd-small hover-bg-dark-transp-25 flex-v-center flex cursor-pointer", { "bg-dark-transp-25": isPlaying(track) }]),
|
|
110
|
+
onClick: ($event) => playTrack(track),
|
|
111
|
+
onDblclick: ($event) => playTrack(track, true),
|
|
112
|
+
onMouseenter: ($event) => hoveredIndex.value = index,
|
|
113
|
+
onMouseleave: _cache[3] || (_cache[3] = ($event) => hoveredIndex.value = -1)
|
|
114
|
+
}, [
|
|
115
|
+
createElementVNode("div", _hoisted_6, [
|
|
116
|
+
!isPlaying(track) && hoveredIndex.value !== index ? (openBlock(), createElementBlock("span", _hoisted_7, toDisplayString(index + 1), 1)) : !isPlaying(track) && hoveredIndex.value === index ? (openBlock(), createBlock(_sfc_main$1, {
|
|
117
|
+
key: 1,
|
|
118
|
+
onClick: withModifiers(($event) => playTrack(track), ["stop"]),
|
|
119
|
+
class: "bg-transparent border-none pd-zero",
|
|
120
|
+
showLoader: false,
|
|
121
|
+
showSucces: false
|
|
122
|
+
}, {
|
|
123
|
+
default: withCtx(() => [
|
|
124
|
+
createVNode(_sfc_main$2, {
|
|
125
|
+
class: "i-small",
|
|
126
|
+
fill: "rgb(var(--white))"
|
|
127
|
+
})
|
|
128
|
+
]),
|
|
129
|
+
_: 2
|
|
130
|
+
}, 1032, ["onClick"])) : (openBlock(), createBlock(_sfc_main$1, {
|
|
131
|
+
key: 2,
|
|
132
|
+
onClick: _cache[0] || (_cache[0] = withModifiers(($event) => pauseTrack(), ["stop"])),
|
|
133
|
+
class: "bg-transparent border-none pd-zero",
|
|
134
|
+
showLoader: false,
|
|
135
|
+
showSucces: false
|
|
136
|
+
}, {
|
|
137
|
+
default: withCtx(() => [
|
|
138
|
+
createVNode(_sfc_main$3, {
|
|
139
|
+
class: "i-small",
|
|
140
|
+
fill: "rgb(var(--main))"
|
|
141
|
+
})
|
|
142
|
+
]),
|
|
143
|
+
_: 1
|
|
144
|
+
}))
|
|
145
|
+
]),
|
|
146
|
+
createElementVNode("div", _hoisted_8, [
|
|
147
|
+
__props.showCover ? (openBlock(), createElementBlock("div", _hoisted_9, [
|
|
148
|
+
createVNode(Media, {
|
|
149
|
+
url: track.coverUrl || track.album && track.album.coverUrl || "/assets/placeholder-track.jpg",
|
|
150
|
+
class: "w-3r h-3r object-fit-cover radius-small"
|
|
151
|
+
}, null, 8, ["url"])
|
|
152
|
+
])) : createCommentVNode("", true),
|
|
153
|
+
createElementVNode("div", _hoisted_10, [
|
|
154
|
+
createElementVNode("div", {
|
|
155
|
+
class: normalizeClass(["track-name t-white", { "t-main": isPlaying(track) }])
|
|
156
|
+
}, toDisplayString(track.title), 3),
|
|
157
|
+
createElementVNode("div", _hoisted_11, [
|
|
158
|
+
track.artist && track.artist._id ? (openBlock(), createBlock(_component_router_link, {
|
|
159
|
+
key: 0,
|
|
160
|
+
to: { name: "artist-detail", params: { url: track.artist.url } },
|
|
161
|
+
class: "t-grey hover-t-white",
|
|
162
|
+
onClick: _cache[1] || (_cache[1] = withModifiers(() => {
|
|
163
|
+
}, ["stop"]))
|
|
164
|
+
}, {
|
|
165
|
+
default: withCtx(() => [
|
|
166
|
+
createTextVNode(toDisplayString(getArtistName(track)), 1)
|
|
167
|
+
]),
|
|
168
|
+
_: 2
|
|
169
|
+
}, 1032, ["to"])) : (openBlock(), createElementBlock("span", _hoisted_12, toDisplayString(getArtistName(track)), 1))
|
|
170
|
+
])
|
|
171
|
+
])
|
|
172
|
+
]),
|
|
173
|
+
__props.showAlbum ? (openBlock(), createElementBlock("div", _hoisted_13, [
|
|
174
|
+
track.album && track.album._id ? (openBlock(), createBlock(_component_router_link, {
|
|
175
|
+
key: 0,
|
|
176
|
+
to: { name: "album-detail", params: { url: track.album.url } },
|
|
177
|
+
class: "t-grey hover-t-white",
|
|
178
|
+
onClick: _cache[2] || (_cache[2] = withModifiers(() => {
|
|
179
|
+
}, ["stop"]))
|
|
180
|
+
}, {
|
|
181
|
+
default: withCtx(() => [
|
|
182
|
+
createTextVNode(toDisplayString(track.album.title), 1)
|
|
183
|
+
]),
|
|
184
|
+
_: 2
|
|
185
|
+
}, 1032, ["to"])) : (openBlock(), createElementBlock("span", _hoisted_14, toDisplayString(((_a = track.album) == null ? void 0 : _a.title) || "Single"), 1))
|
|
186
|
+
])) : createCommentVNode("", true),
|
|
187
|
+
createElementVNode("div", _hoisted_15, toDisplayString(formatDuration(track.duration)), 1)
|
|
188
|
+
], 42, _hoisted_5);
|
|
189
|
+
}), 128))
|
|
190
|
+
])
|
|
191
|
+
]);
|
|
192
|
+
};
|
|
193
|
+
}
|
|
194
|
+
};
|
|
195
|
+
const TrackList = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-23a9470b"]]);
|
|
196
|
+
export {
|
|
197
|
+
TrackList as default
|
|
198
|
+
};
|
|
199
|
+
//# sourceMappingURL=TrackList.vue.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TrackList.vue.js","sources":["../../../../../../../src/modules/music/components/lists/TrackList.vue"],"sourcesContent":["<!-- components/lists/TrackList.vue (continued) -->\n<template>\n <div class=\"track-list w-100\">\n <div \n v-if=\"showHeader\" \n class=\"track-list-header pd-small br-b br-solid br-dark-transp-20 t-grey flex-v-center flex\"\n >\n <div class=\"track-number w-3r t-center\">#</div>\n <div class=\"track-title flex-child-1\">TITLE</div>\n <div v-if=\"showAlbum\" class=\"track-album w-15r mobile:w-0 mobile:hidden\">ALBUM</div>\n <div class=\"track-duration w-5r t-right\">DURATION</div>\n </div>\n \n <div class=\"track-list-body\">\n <div \n v-for=\"(track, index) in tracks\" \n :key=\"track._id\"\n class=\"track-item pd-small hover-bg-dark-transp-25 flex-v-center flex cursor-pointer\"\n :class=\"{'bg-dark-transp-25': isPlaying(track)}\"\n @click=\"playTrack(track)\"\n @dblclick=\"playTrack(track, true)\"\n @mouseenter=\"hoveredIndex = index\"\n @mouseleave=\"hoveredIndex = -1\"\n >\n <div class=\"track-number w-3r t-center pos-relative\">\n <span v-if=\"!isPlaying(track) && hoveredIndex !== index\" class=\"t-grey\">{{ index + 1 }}</span>\n <Button \n v-else-if=\"!isPlaying(track) && hoveredIndex === index\"\n @click.stop=\"playTrack(track)\"\n class=\"bg-transparent border-none pd-zero\"\n :showLoader=\"false\"\n :showSucces=\"false\"\n >\n <IconPlay class=\"i-small\" fill=\"rgb(var(--white))\"/>\n </Button>\n <Button \n v-else\n @click.stop=\"pauseTrack()\"\n class=\"bg-transparent border-none pd-zero\"\n :showLoader=\"false\"\n :showSucces=\"false\"\n >\n <IconPause class=\"i-small\" fill=\"rgb(var(--main))\"/>\n </Button>\n </div>\n \n <div class=\"track-title flex-child-1 flex flex-v-center\">\n <div v-if=\"showCover\" class=\"track-cover mn-r-small\">\n <Media \n :url=\"track.coverUrl || (track.album && track.album.coverUrl) || '/assets/placeholder-track.jpg'\" \n class=\"w-3r h-3r object-fit-cover radius-small\"\n />\n </div>\n \n <div class=\"track-info\">\n <div class=\"track-name t-white\" :class=\"{'t-main': isPlaying(track)}\">{{ track.title }}</div>\n <div class=\"track-artist t-grey t-small\">\n <router-link \n v-if=\"track.artist && track.artist._id\"\n :to=\"{ name: 'artist-detail', params: { url: track.artist.url } }\"\n class=\"t-grey hover-t-white\"\n @click.stop\n >\n {{ getArtistName(track) }}\n </router-link>\n <span v-else>{{ getArtistName(track) }}</span>\n </div>\n </div>\n </div>\n \n <div v-if=\"showAlbum\" class=\"track-album w-15r mobile:w-0 mobile:hidden t-grey t-truncate\">\n <router-link \n v-if=\"track.album && track.album._id\"\n :to=\"{ name: 'album-detail', params: { url: track.album.url } }\"\n class=\"t-grey hover-t-white\"\n @click.stop\n >\n {{ track.album.title }}\n </router-link>\n <span v-else>{{ track.album?.title || 'Single' }}</span>\n </div>\n \n <div class=\"track-duration w-5r t-right t-grey\">{{ formatDuration(track.duration) }}</div>\n </div>\n </div>\n </div>\n</template>\n\n<script setup>\nimport { ref, computed } from 'vue';\nimport Media from '@martyrs/src/components/Media/Media.vue';\nimport Button from '@martyrs/src/components/Button/Button.vue';\nimport IconPlay from '@martyrs/src/modules/icons/navigation/IconPlay.vue';\nimport IconPause from '@martyrs/src/modules/icons/navigation/IconPause.vue';\n\n// Import player store\nimport { state as playerState, actions as playerActions } from '../../store/player.js';\n\nconst props = defineProps({\n tracks: {\n type: Array,\n required: true\n },\n showHeader: {\n type: Boolean,\n default: true\n },\n showAlbum: {\n type: Boolean,\n default: false\n },\n showCover: {\n type: Boolean,\n default: false\n },\n showIndex: {\n type: Boolean,\n default: true\n }\n});\n\n// State\nconst hoveredIndex = ref(-1);\n\n// Computed\nconst currentTrack = computed(() => playerState.currentTrack);\n\n// Methods\nconst isPlaying = (track) => {\n return currentTrack.value && currentTrack.value._id === track._id && isPlaying.value;\n};\n\nconst isHovering = (index) => {\n return hoveredIndex.value === index;\n};\n\nconst playTrack = (track, addToQueue = false) => {\n if (addToQueue) {\n playerActions.addToQueue(track);\n } else {\n // Find track index to set queue properly\n const trackIndex = props.tracks.findIndex(t => t._id === track._id);\n playerActions.setQueue([...props.tracks], trackIndex);\n }\n};\n\nconst pauseTrack = () => {\n playerActions.togglePlay();\n};\n\nconst getArtistName = (track) => {\n if (track.artist) {\n if (typeof track.artist === 'object') {\n return track.artist.name || 'Unknown Artist';\n }\n return track.artist;\n }\n return 'Unknown Artist';\n};\n\nconst formatDuration = (seconds) => {\n if (!seconds) return '0:00';\n \n const minutes = Math.floor(seconds / 60);\n const remainingSeconds = Math.floor(seconds % 60);\n \n return `${minutes}:${remainingSeconds.toString().padStart(2, '0')}`;\n};\n</script>\n\n<style scoped>\n.track-item {\n transition: background-color 0.2s ease;\n}\n</style>"],"names":["playerState","playerActions"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAkGA,UAAM,QAAQ;AAwBd,UAAM,eAAe,IAAI,EAAE;AAG3B,UAAM,eAAe,SAAS,MAAMA,MAAY,YAAY;AAG5D,UAAM,YAAY,CAAC,UAAU;AAC3B,aAAO,aAAa,SAAS,aAAa,MAAM,QAAQ,MAAM,OAAO,UAAU;AAAA,IACjF;AAMA,UAAM,YAAY,CAAC,OAAO,aAAa,UAAU;AAC/C,UAAI,YAAY;AACdC,gBAAc,WAAW,KAAK;AAAA,MAClC,OAAS;AAEL,cAAM,aAAa,MAAM,OAAO,UAAU,OAAK,EAAE,QAAQ,MAAM,GAAG;AAClEA,gBAAc,SAAS,CAAC,GAAG,MAAM,MAAM,GAAG,UAAU;AAAA,MACxD;AAAA,IACA;AAEA,UAAM,aAAa,MAAM;AACvBA,cAAc,WAAY;AAAA,IAC5B;AAEA,UAAM,gBAAgB,CAAC,UAAU;AAC/B,UAAI,MAAM,QAAQ;AAChB,YAAI,OAAO,MAAM,WAAW,UAAU;AACpC,iBAAO,MAAM,OAAO,QAAQ;AAAA,QAClC;AACI,eAAO,MAAM;AAAA,MACjB;AACE,aAAO;AAAA,IACT;AAEA,UAAM,iBAAiB,CAAC,YAAY;AAClC,UAAI,CAAC,QAAS,QAAO;AAErB,YAAM,UAAU,KAAK,MAAM,UAAU,EAAE;AACvC,YAAM,mBAAmB,KAAK,MAAM,UAAU,EAAE;AAEhD,aAAO,GAAG,OAAO,IAAI,iBAAiB,SAAU,EAAC,SAAS,GAAG,GAAG,CAAC;AAAA,IACnE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -0,0 +1,290 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
|
|
3
|
+
const vue = require("vue");
|
|
4
|
+
const vueRouter = require("vue-router");
|
|
5
|
+
const TrackList = require("../lists/TrackList.vue.cjs");
|
|
6
|
+
const AlbumCard = require("../cards/AlbumCard.vue.cjs");
|
|
7
|
+
const Button = require("../../../../components/Button/Button.vue.cjs");
|
|
8
|
+
const Loader = require("../../../../components/Loader/Loader.vue2.cjs");
|
|
9
|
+
const Media = require("../../../../components/Media/Media.vue.cjs");
|
|
10
|
+
const Dropdown = require("../../../../components/Dropdown/Dropdown.vue.cjs");
|
|
11
|
+
const IconPlay = require("../../../icons/navigation/IconPlay.vue.cjs");
|
|
12
|
+
const IconLike = require("../../../icons/navigation/IconLike.vue.cjs");
|
|
13
|
+
const IconEllipsis = require("../../../icons/navigation/IconEllipsis.vue.cjs");
|
|
14
|
+
const albums = require("../../store/albums.cjs");
|
|
15
|
+
const player = require("../../store/player.cjs");
|
|
16
|
+
const _pluginVue_exportHelper = require("../../../../../../_virtual/_plugin-vue_export-helper.cjs");
|
|
17
|
+
const _hoisted_1 = { class: "album-detail-page" };
|
|
18
|
+
const _hoisted_2 = {
|
|
19
|
+
key: 0,
|
|
20
|
+
class: "w-100 h-25r flex-center flex"
|
|
21
|
+
};
|
|
22
|
+
const _hoisted_3 = {
|
|
23
|
+
key: 1,
|
|
24
|
+
class: "t-center pd-big"
|
|
25
|
+
};
|
|
26
|
+
const _hoisted_4 = { key: 2 };
|
|
27
|
+
const _hoisted_5 = { class: "album-header mn-b-medium flex flex-v-center gap-medium" };
|
|
28
|
+
const _hoisted_6 = { class: "album-cover" };
|
|
29
|
+
const _hoisted_7 = { class: "album-info" };
|
|
30
|
+
const _hoisted_8 = { class: "t-white" };
|
|
31
|
+
const _hoisted_9 = { class: "album-meta mn-t-small flex flex-v-center" };
|
|
32
|
+
const _hoisted_10 = {
|
|
33
|
+
key: 1,
|
|
34
|
+
class: "t-white t-medium"
|
|
35
|
+
};
|
|
36
|
+
const _hoisted_11 = { class: "t-grey" };
|
|
37
|
+
const _hoisted_12 = { class: "t-grey" };
|
|
38
|
+
const _hoisted_13 = { class: "album-actions mn-b-medium flex flex-v-center gap-small" };
|
|
39
|
+
const _hoisted_14 = {
|
|
40
|
+
key: 0,
|
|
41
|
+
class: "pd-small bg-dark radius-small pos-absolute pos-t-100 pos-r-0 z-index-3 w-max-15r mn-t-thin"
|
|
42
|
+
};
|
|
43
|
+
const _hoisted_15 = { class: "mn-b-thin" };
|
|
44
|
+
const _hoisted_16 = { class: "album-tracks" };
|
|
45
|
+
const _hoisted_17 = {
|
|
46
|
+
key: 0,
|
|
47
|
+
class: "album-description mn-t-medium pd-medium bg-dark-transp-10 radius-medium"
|
|
48
|
+
};
|
|
49
|
+
const _hoisted_18 = { class: "t-grey" };
|
|
50
|
+
const _hoisted_19 = {
|
|
51
|
+
key: 1,
|
|
52
|
+
class: "more-from-artist mn-t-medium"
|
|
53
|
+
};
|
|
54
|
+
const _hoisted_20 = { class: "flex-between flex mn-b-small" };
|
|
55
|
+
const _hoisted_21 = { class: "t-white" };
|
|
56
|
+
const _hoisted_22 = { class: "albums-grid cols-5 mobile:cols-2 gap-small" };
|
|
57
|
+
const _sfc_main = {
|
|
58
|
+
__name: "AlbumDetail",
|
|
59
|
+
setup(__props) {
|
|
60
|
+
const route = vueRouter.useRoute();
|
|
61
|
+
vueRouter.useRouter();
|
|
62
|
+
const isLoading = vue.ref(true);
|
|
63
|
+
const isFavorite = vue.ref(false);
|
|
64
|
+
const showDropdown = vue.ref(false);
|
|
65
|
+
const moreFromArtist = vue.ref([]);
|
|
66
|
+
const album = vue.computed(() => albums.state.currentAlbum);
|
|
67
|
+
const albumTracks = vue.computed(() => albums.state.currentAlbumTracks);
|
|
68
|
+
const getArtistName = (albumItem) => {
|
|
69
|
+
if (!albumItem) return "Unknown Artist";
|
|
70
|
+
if (albumItem.artist) {
|
|
71
|
+
if (typeof albumItem.artist === "object") {
|
|
72
|
+
return albumItem.artist.name || "Unknown Artist";
|
|
73
|
+
}
|
|
74
|
+
return albumItem.artist;
|
|
75
|
+
}
|
|
76
|
+
return "Unknown Artist";
|
|
77
|
+
};
|
|
78
|
+
const formatReleaseYear = (dateString) => {
|
|
79
|
+
if (!dateString) return "";
|
|
80
|
+
return new Date(dateString).getFullYear();
|
|
81
|
+
};
|
|
82
|
+
const playAlbum = () => {
|
|
83
|
+
if (albumTracks.value && albumTracks.value.length > 0) {
|
|
84
|
+
player.actions.setQueue(albumTracks.value);
|
|
85
|
+
}
|
|
86
|
+
};
|
|
87
|
+
const toggleFavorite = () => {
|
|
88
|
+
isFavorite.value = !isFavorite.value;
|
|
89
|
+
};
|
|
90
|
+
const addToQueue = () => {
|
|
91
|
+
if (albumTracks.value && albumTracks.value.length > 0) {
|
|
92
|
+
albumTracks.value.forEach((track) => {
|
|
93
|
+
player.actions.addToQueue(track);
|
|
94
|
+
});
|
|
95
|
+
showDropdown.value = false;
|
|
96
|
+
}
|
|
97
|
+
};
|
|
98
|
+
const copyLink = () => {
|
|
99
|
+
const url = window.location.href;
|
|
100
|
+
navigator.clipboard.writeText(url).then(() => {
|
|
101
|
+
showDropdown.value = false;
|
|
102
|
+
});
|
|
103
|
+
};
|
|
104
|
+
const fetchAlbumData = async () => {
|
|
105
|
+
var _a, _b;
|
|
106
|
+
isLoading.value = true;
|
|
107
|
+
try {
|
|
108
|
+
await albums.actions.fetchAlbumByUrl(route.params.url);
|
|
109
|
+
if ((_b = (_a = album.value) == null ? void 0 : _a.artist) == null ? void 0 : _b._id) {
|
|
110
|
+
const artistAlbums = await albums.actions.fetchAlbums({
|
|
111
|
+
artist: album.value.artist._id,
|
|
112
|
+
status: "published",
|
|
113
|
+
isPublic: true,
|
|
114
|
+
limit: 5
|
|
115
|
+
});
|
|
116
|
+
moreFromArtist.value = artistAlbums.filter((a) => a._id !== album.value._id);
|
|
117
|
+
}
|
|
118
|
+
} catch (error) {
|
|
119
|
+
console.error("Error fetching album data:", error);
|
|
120
|
+
} finally {
|
|
121
|
+
isLoading.value = false;
|
|
122
|
+
}
|
|
123
|
+
};
|
|
124
|
+
vue.onMounted(fetchAlbumData);
|
|
125
|
+
vue.watch(() => route.params.url, (newUrl) => {
|
|
126
|
+
if (newUrl) {
|
|
127
|
+
fetchAlbumData();
|
|
128
|
+
}
|
|
129
|
+
});
|
|
130
|
+
return (_ctx, _cache) => {
|
|
131
|
+
const _component_router_link = vue.resolveComponent("router-link");
|
|
132
|
+
return vue.openBlock(), vue.createElementBlock("div", _hoisted_1, [
|
|
133
|
+
isLoading.value ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_2, [
|
|
134
|
+
vue.createVNode(Loader.default)
|
|
135
|
+
])) : !album.value ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_3, _cache[1] || (_cache[1] = [
|
|
136
|
+
vue.createElementVNode("h2", { class: "t-white" }, "Album not found", -1),
|
|
137
|
+
vue.createElementVNode("p", { class: "t-grey t-medium" }, "The album you're looking for doesn't exist or has been removed.", -1)
|
|
138
|
+
]))) : (vue.openBlock(), vue.createElementBlock("div", _hoisted_4, [
|
|
139
|
+
vue.createElementVNode("div", _hoisted_5, [
|
|
140
|
+
vue.createElementVNode("div", _hoisted_6, [
|
|
141
|
+
vue.createVNode(Media.default, {
|
|
142
|
+
url: album.value.coverUrl || "/assets/placeholder-album.jpg",
|
|
143
|
+
class: "w-15r h-15r object-fit-cover shadow-lg radius-small"
|
|
144
|
+
}, null, 8, ["url"])
|
|
145
|
+
]),
|
|
146
|
+
vue.createElementVNode("div", _hoisted_7, [
|
|
147
|
+
_cache[4] || (_cache[4] = vue.createElementVNode("div", { class: "t-small t-uppercase t-white" }, "Album", -1)),
|
|
148
|
+
vue.createElementVNode("h1", _hoisted_8, vue.toDisplayString(album.value.title), 1),
|
|
149
|
+
vue.createElementVNode("div", _hoisted_9, [
|
|
150
|
+
album.value.artist && album.value.artist._id ? (vue.openBlock(), vue.createBlock(_component_router_link, {
|
|
151
|
+
key: 0,
|
|
152
|
+
to: { name: "artist-detail", params: { url: album.value.artist.url } },
|
|
153
|
+
class: "t-white t-medium hover-t-main"
|
|
154
|
+
}, {
|
|
155
|
+
default: vue.withCtx(() => [
|
|
156
|
+
vue.createTextVNode(vue.toDisplayString(getArtistName(album.value)), 1)
|
|
157
|
+
]),
|
|
158
|
+
_: 1
|
|
159
|
+
}, 8, ["to"])) : (vue.openBlock(), vue.createElementBlock("span", _hoisted_10, vue.toDisplayString(getArtistName(album.value)), 1)),
|
|
160
|
+
_cache[2] || (_cache[2] = vue.createElementVNode("span", { class: "t-grey mn-l-small mn-r-small" }, "•", -1)),
|
|
161
|
+
vue.createElementVNode("span", _hoisted_11, vue.toDisplayString(formatReleaseYear(album.value.releaseDate)), 1),
|
|
162
|
+
_cache[3] || (_cache[3] = vue.createElementVNode("span", { class: "t-grey mn-l-small mn-r-small" }, "•", -1)),
|
|
163
|
+
vue.createElementVNode("span", _hoisted_12, vue.toDisplayString(albumTracks.value.length) + " " + vue.toDisplayString(albumTracks.value.length === 1 ? "song" : "songs"), 1)
|
|
164
|
+
])
|
|
165
|
+
])
|
|
166
|
+
]),
|
|
167
|
+
vue.createElementVNode("div", _hoisted_13, [
|
|
168
|
+
vue.createVNode(Button.default, {
|
|
169
|
+
onClick: playAlbum,
|
|
170
|
+
class: "play-button bg-main radius-round pd-small flex-v-center flex gap-small hover-scale-1",
|
|
171
|
+
showLoader: false,
|
|
172
|
+
showSucces: false
|
|
173
|
+
}, {
|
|
174
|
+
default: vue.withCtx(() => [
|
|
175
|
+
vue.createVNode(IconPlay.default, {
|
|
176
|
+
class: "i-small",
|
|
177
|
+
fill: "rgb(var(--black))"
|
|
178
|
+
}),
|
|
179
|
+
_cache[5] || (_cache[5] = vue.createElementVNode("span", { class: "t-black t-medium" }, "Play", -1))
|
|
180
|
+
]),
|
|
181
|
+
_: 1
|
|
182
|
+
}),
|
|
183
|
+
vue.createVNode(Button.default, {
|
|
184
|
+
onClick: toggleFavorite,
|
|
185
|
+
class: "bg-transparent border-none pd-zero",
|
|
186
|
+
showLoader: false,
|
|
187
|
+
showSucces: false
|
|
188
|
+
}, {
|
|
189
|
+
default: vue.withCtx(() => [
|
|
190
|
+
vue.createVNode(IconLike.default, {
|
|
191
|
+
class: "i-medium",
|
|
192
|
+
fill: isFavorite.value ? "rgb(var(--main))" : "rgb(var(--white))"
|
|
193
|
+
}, null, 8, ["fill"])
|
|
194
|
+
]),
|
|
195
|
+
_: 1
|
|
196
|
+
}),
|
|
197
|
+
vue.createVNode(Dropdown.default, { class: "pos-relative" }, {
|
|
198
|
+
content: vue.withCtx(() => [
|
|
199
|
+
showDropdown.value ? (vue.openBlock(), vue.createElementBlock("ul", _hoisted_14, [
|
|
200
|
+
vue.createElementVNode("li", _hoisted_15, [
|
|
201
|
+
vue.createVNode(Button.default, {
|
|
202
|
+
onClick: addToQueue,
|
|
203
|
+
class: "bg-transparent border-none pd-thin t-white w-100 t-left hover-bg-dark radius-small",
|
|
204
|
+
showLoader: false,
|
|
205
|
+
showSucces: false
|
|
206
|
+
}, {
|
|
207
|
+
default: vue.withCtx(() => _cache[6] || (_cache[6] = [
|
|
208
|
+
vue.createElementVNode("span", null, "Add to Queue", -1)
|
|
209
|
+
])),
|
|
210
|
+
_: 1
|
|
211
|
+
})
|
|
212
|
+
]),
|
|
213
|
+
vue.createElementVNode("li", null, [
|
|
214
|
+
vue.createVNode(Button.default, {
|
|
215
|
+
onClick: copyLink,
|
|
216
|
+
class: "bg-transparent border-none pd-thin t-white w-100 t-left hover-bg-dark radius-small",
|
|
217
|
+
showLoader: false,
|
|
218
|
+
showSucces: false
|
|
219
|
+
}, {
|
|
220
|
+
default: vue.withCtx(() => _cache[7] || (_cache[7] = [
|
|
221
|
+
vue.createElementVNode("span", null, "Copy Link", -1)
|
|
222
|
+
])),
|
|
223
|
+
_: 1
|
|
224
|
+
})
|
|
225
|
+
])
|
|
226
|
+
])) : vue.createCommentVNode("", true)
|
|
227
|
+
]),
|
|
228
|
+
default: vue.withCtx(() => [
|
|
229
|
+
vue.createVNode(Button.default, {
|
|
230
|
+
onClick: _cache[0] || (_cache[0] = ($event) => showDropdown.value = !showDropdown.value),
|
|
231
|
+
class: "bg-transparent border-none pd-zero",
|
|
232
|
+
showLoader: false,
|
|
233
|
+
showSucces: false
|
|
234
|
+
}, {
|
|
235
|
+
default: vue.withCtx(() => [
|
|
236
|
+
vue.createVNode(IconEllipsis.default, {
|
|
237
|
+
class: "i-medium",
|
|
238
|
+
fill: "rgb(var(--white))"
|
|
239
|
+
})
|
|
240
|
+
]),
|
|
241
|
+
_: 1
|
|
242
|
+
})
|
|
243
|
+
]),
|
|
244
|
+
_: 1
|
|
245
|
+
})
|
|
246
|
+
]),
|
|
247
|
+
vue.createElementVNode("div", _hoisted_16, [
|
|
248
|
+
vue.createVNode(TrackList.default, {
|
|
249
|
+
tracks: albumTracks.value,
|
|
250
|
+
showAlbum: false,
|
|
251
|
+
showCover: false,
|
|
252
|
+
class: "bg-dark-transp-10 radius-medium o-hidden"
|
|
253
|
+
}, null, 8, ["tracks"])
|
|
254
|
+
]),
|
|
255
|
+
album.value.description ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_17, [
|
|
256
|
+
_cache[8] || (_cache[8] = vue.createElementVNode("h3", { class: "t-white mn-b-small" }, "About", -1)),
|
|
257
|
+
vue.createElementVNode("p", _hoisted_18, vue.toDisplayString(album.value.description), 1)
|
|
258
|
+
])) : vue.createCommentVNode("", true),
|
|
259
|
+
moreFromArtist.value.length > 0 ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_19, [
|
|
260
|
+
vue.createElementVNode("div", _hoisted_20, [
|
|
261
|
+
vue.createElementVNode("h2", _hoisted_21, "More by " + vue.toDisplayString(getArtistName(album.value)), 1),
|
|
262
|
+
album.value.artist && album.value.artist._id ? (vue.openBlock(), vue.createBlock(_component_router_link, {
|
|
263
|
+
key: 0,
|
|
264
|
+
to: { name: "artist-detail", params: { url: album.value.artist.url } },
|
|
265
|
+
class: "t-main t-small hover-opacity"
|
|
266
|
+
}, {
|
|
267
|
+
default: vue.withCtx(() => _cache[9] || (_cache[9] = [
|
|
268
|
+
vue.createTextVNode(" See all ")
|
|
269
|
+
])),
|
|
270
|
+
_: 1
|
|
271
|
+
}, 8, ["to"])) : vue.createCommentVNode("", true)
|
|
272
|
+
]),
|
|
273
|
+
vue.createElementVNode("div", _hoisted_22, [
|
|
274
|
+
(vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(moreFromArtist.value, (relatedAlbum) => {
|
|
275
|
+
return vue.openBlock(), vue.createElementBlock("div", {
|
|
276
|
+
key: relatedAlbum._id
|
|
277
|
+
}, [
|
|
278
|
+
vue.createVNode(AlbumCard.default, { album: relatedAlbum }, null, 8, ["album"])
|
|
279
|
+
]);
|
|
280
|
+
}), 128))
|
|
281
|
+
])
|
|
282
|
+
])) : vue.createCommentVNode("", true)
|
|
283
|
+
]))
|
|
284
|
+
]);
|
|
285
|
+
};
|
|
286
|
+
}
|
|
287
|
+
};
|
|
288
|
+
const AlbumDetail = /* @__PURE__ */ _pluginVue_exportHelper.default(_sfc_main, [["__scopeId", "data-v-f076792b"]]);
|
|
289
|
+
exports.default = AlbumDetail;
|
|
290
|
+
//# sourceMappingURL=AlbumDetail.vue.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AlbumDetail.vue.cjs","sources":["../../../../../../../src/modules/music/components/pages/AlbumDetail.vue"],"sourcesContent":["<!-- components/pages/AlbumDetail.vue -->\n<template>\n <div class=\"album-detail-page\">\n <div v-if=\"isLoading\" class=\"w-100 h-25r flex-center flex\">\n <Loader />\n </div>\n \n <div v-else-if=\"!album\" class=\"t-center pd-big\">\n <h2 class=\"t-white\">Album not found</h2>\n <p class=\"t-grey t-medium\">The album you're looking for doesn't exist or has been removed.</p>\n </div>\n \n <div v-else>\n <!-- Album Header -->\n <div class=\"album-header mn-b-medium flex flex-v-center gap-medium\">\n <div class=\"album-cover\">\n <Media \n :url=\"album.coverUrl || '/assets/placeholder-album.jpg'\" \n class=\"w-15r h-15r object-fit-cover shadow-lg radius-small\"\n />\n </div>\n \n <div class=\"album-info\">\n <div class=\"t-small t-uppercase t-white\">Album</div>\n <h1 class=\"t-white\">{{ album.title }}</h1>\n \n <div class=\"album-meta mn-t-small flex flex-v-center\">\n <router-link \n v-if=\"album.artist && album.artist._id\"\n :to=\"{ name: 'artist-detail', params: { url: album.artist.url } }\"\n class=\"t-white t-medium hover-t-main\"\n >\n {{ getArtistName(album) }}\n </router-link>\n <span v-else class=\"t-white t-medium\">{{ getArtistName(album) }}</span>\n \n <span class=\"t-grey mn-l-small mn-r-small\">•</span>\n \n <span class=\"t-grey\">{{ formatReleaseYear(album.releaseDate) }}</span>\n \n <span class=\"t-grey mn-l-small mn-r-small\">•</span>\n \n <span class=\"t-grey\">{{ albumTracks.length }} {{ albumTracks.length === 1 ? 'song' : 'songs' }}</span>\n </div>\n </div>\n </div>\n \n <!-- Album Actions -->\n <div class=\"album-actions mn-b-medium flex flex-v-center gap-small\">\n <Button \n @click=\"playAlbum\"\n class=\"play-button bg-main radius-round pd-small flex-v-center flex gap-small hover-scale-1\"\n :showLoader=\"false\" \n :showSucces=\"false\"\n >\n <IconPlay class=\"i-small\" fill=\"rgb(var(--black))\"/>\n <span class=\"t-black t-medium\">Play</span>\n </Button>\n \n <Button \n @click=\"toggleFavorite\"\n class=\"bg-transparent border-none pd-zero\"\n :showLoader=\"false\" \n :showSucces=\"false\"\n >\n <IconLike class=\"i-medium\" :fill=\"isFavorite ? 'rgb(var(--main))' : 'rgb(var(--white))'\"/>\n </Button>\n \n <Dropdown class=\"pos-relative\">\n <Button \n @click=\"showDropdown = !showDropdown\"\n class=\"bg-transparent border-none pd-zero\"\n :showLoader=\"false\" \n :showSucces=\"false\"\n >\n <IconEllipsis class=\"i-medium\" fill=\"rgb(var(--white))\"/>\n </Button>\n \n <template #content>\n <ul v-if=\"showDropdown\" class=\"pd-small bg-dark radius-small pos-absolute pos-t-100 pos-r-0 z-index-3 w-max-15r mn-t-thin\">\n <li class=\"mn-b-thin\">\n <Button \n @click=\"addToQueue\"\n class=\"bg-transparent border-none pd-thin t-white w-100 t-left hover-bg-dark radius-small\"\n :showLoader=\"false\" \n :showSucces=\"false\"\n >\n <span>Add to Queue</span>\n </Button>\n </li>\n <li>\n <Button \n @click=\"copyLink\"\n class=\"bg-transparent border-none pd-thin t-white w-100 t-left hover-bg-dark radius-small\"\n :showLoader=\"false\" \n :showSucces=\"false\"\n >\n <span>Copy Link</span>\n </Button>\n </li>\n </ul>\n </template>\n </Dropdown>\n </div>\n \n <!-- Album Tracks -->\n <div class=\"album-tracks\">\n <TrackList \n :tracks=\"albumTracks\"\n :showAlbum=\"false\"\n :showCover=\"false\"\n class=\"bg-dark-transp-10 radius-medium o-hidden\"\n />\n </div>\n \n <!-- Album Info -->\n <div v-if=\"album.description\" class=\"album-description mn-t-medium pd-medium bg-dark-transp-10 radius-medium\">\n <h3 class=\"t-white mn-b-small\">About</h3>\n <p class=\"t-grey\">{{ album.description }}</p>\n </div>\n \n <!-- More from this artist if available -->\n <div v-if=\"moreFromArtist.length > 0\" class=\"more-from-artist mn-t-medium\">\n <div class=\"flex-between flex mn-b-small\">\n <h2 class=\"t-white\">More by {{ getArtistName(album) }}</h2>\n <router-link \n v-if=\"album.artist && album.artist._id\"\n :to=\"{ name: 'artist-detail', params: { url: album.artist.url } }\" \n class=\"t-main t-small hover-opacity\"\n >\n See all\n </router-link>\n </div>\n \n <div class=\"albums-grid cols-5 mobile:cols-2 gap-small\">\n <div v-for=\"relatedAlbum in moreFromArtist\" :key=\"relatedAlbum._id\">\n <AlbumCard :album=\"relatedAlbum\" />\n </div>\n </div>\n </div>\n </div>\n </div>\n</template>\n\n<script setup>\nimport { ref, computed, onMounted, watch } from 'vue';\nimport { useRoute, useRouter } from 'vue-router';\nimport TrackList from '../lists/TrackList.vue';\nimport AlbumCard from '../cards/AlbumCard.vue';\nimport Button from '@martyrs/src/components/Button/Button.vue';\nimport Loader from '@martyrs/src/components/Loader/Loader.vue';\nimport Media from '@martyrs/src/components/Media/Media.vue';\nimport Dropdown from '@martyrs/src/components/Dropdown/Dropdown.vue';\n\n// Import icons\nimport IconPlay from '@martyrs/src/modules/icons/navigation/IconPlay.vue';\nimport IconLike from '@martyrs/src/modules/icons/navigation/IconLike.vue';\nimport IconEllipsis from '@martyrs/src/modules/icons/navigation/IconEllipsis.vue';\n\n// Import store modules\nimport { state as albumsState, actions as albumsActions } from '../../store/albums.js';\nimport { actions as playerActions } from '../../store/player.js';\n\nconst route = useRoute();\nconst router = useRouter();\n\n// State\nconst isLoading = ref(true);\nconst isFavorite = ref(false);\nconst showDropdown = ref(false);\nconst moreFromArtist = ref([]);\n\n// Computed properties\nconst album = computed(() => albumsState.currentAlbum);\nconst albumTracks = computed(() => albumsState.currentAlbumTracks);\n\n// Methods\nconst getArtistName = (albumItem) => {\n if (!albumItem) return 'Unknown Artist';\n \n if (albumItem.artist) {\n if (typeof albumItem.artist === 'object') {\n return albumItem.artist.name || 'Unknown Artist';\n }\n return albumItem.artist;\n }\n return 'Unknown Artist';\n};\n\nconst formatReleaseYear = (dateString) => {\n if (!dateString) return '';\n return new Date(dateString).getFullYear();\n};\n\nconst playAlbum = () => {\n if (albumTracks.value && albumTracks.value.length > 0) {\n playerActions.setQueue(albumTracks.value);\n }\n};\n\nconst toggleFavorite = () => {\n isFavorite.value = !isFavorite.value;\n // Implement favorite album logic here\n};\n\nconst addToQueue = () => {\n if (albumTracks.value && albumTracks.value.length > 0) {\n // Add all tracks to queue\n albumTracks.value.forEach(track => {\n playerActions.addToQueue(track);\n });\n \n showDropdown.value = false;\n }\n};\n\nconst copyLink = () => {\n const url = window.location.href;\n navigator.clipboard.writeText(url).then(() => {\n // Could show a success notification here\n showDropdown.value = false;\n });\n};\n\nconst fetchAlbumData = async () => {\n isLoading.value = true;\n \n try {\n // Fetch album data\n await albumsActions.fetchAlbumByUrl(route.params.url);\n \n // If artist is available, fetch more albums from the same artist\n if (album.value?.artist?._id) {\n const artistAlbums = await albumsActions.fetchAlbums({\n artist: album.value.artist._id,\n status: 'published',\n isPublic: true,\n limit: 5\n });\n \n // Filter out the current album\n moreFromArtist.value = artistAlbums.filter(a => a._id !== album.value._id);\n }\n } catch (error) {\n console.error('Error fetching album data:', error);\n } finally {\n isLoading.value = false;\n }\n};\n\n// Fetch data when component mounts or URL changes\nonMounted(fetchAlbumData);\n\nwatch(() => route.params.url, (newUrl) => {\n if (newUrl) {\n fetchAlbumData();\n }\n});\n</script>\n\n<style scoped>\n.album-cover {\n box-shadow: 0 4px 60px rgba(0, 0, 0, 0.5);\n}\n</style>"],"names":["useRoute","useRouter","ref","computed","albumsState","playerActions","albumsActions","onMounted","watch"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAmKA,UAAM,QAAQA,UAAAA,SAAU;AACTC,cAAS,UAAA;AAGxB,UAAM,YAAYC,IAAG,IAAC,IAAI;AAC1B,UAAM,aAAaA,IAAG,IAAC,KAAK;AAC5B,UAAM,eAAeA,IAAG,IAAC,KAAK;AAC9B,UAAM,iBAAiBA,IAAG,IAAC,EAAE;AAG7B,UAAM,QAAQC,IAAQ,SAAC,MAAMC,OAAW,MAAC,YAAY;AACrD,UAAM,cAAcD,IAAQ,SAAC,MAAMC,OAAW,MAAC,kBAAkB;AAGjE,UAAM,gBAAgB,CAAC,cAAc;AACnC,UAAI,CAAC,UAAW,QAAO;AAEvB,UAAI,UAAU,QAAQ;AACpB,YAAI,OAAO,UAAU,WAAW,UAAU;AACxC,iBAAO,UAAU,OAAO,QAAQ;AAAA,QACtC;AACI,eAAO,UAAU;AAAA,MACrB;AACE,aAAO;AAAA,IACT;AAEA,UAAM,oBAAoB,CAAC,eAAe;AACxC,UAAI,CAAC,WAAY,QAAO;AACxB,aAAO,IAAI,KAAK,UAAU,EAAE,YAAa;AAAA,IAC3C;AAEA,UAAM,YAAY,MAAM;AACtB,UAAI,YAAY,SAAS,YAAY,MAAM,SAAS,GAAG;AACrDC,uBAAc,SAAS,YAAY,KAAK;AAAA,MAC5C;AAAA,IACA;AAEA,UAAM,iBAAiB,MAAM;AAC3B,iBAAW,QAAQ,CAAC,WAAW;AAAA,IAEjC;AAEA,UAAM,aAAa,MAAM;AACvB,UAAI,YAAY,SAAS,YAAY,MAAM,SAAS,GAAG;AAErD,oBAAY,MAAM,QAAQ,WAAS;AACjCA,iBAAa,QAAC,WAAW,KAAK;AAAA,QACpC,CAAK;AAED,qBAAa,QAAQ;AAAA,MACzB;AAAA,IACA;AAEA,UAAM,WAAW,MAAM;AACrB,YAAM,MAAM,OAAO,SAAS;AAC5B,gBAAU,UAAU,UAAU,GAAG,EAAE,KAAK,MAAM;AAE5C,qBAAa,QAAQ;AAAA,MACzB,CAAG;AAAA,IACH;AAEA,UAAM,iBAAiB,YAAY;;AACjC,gBAAU,QAAQ;AAElB,UAAI;AAEF,cAAMC,OAAa,QAAC,gBAAgB,MAAM,OAAO,GAAG;AAGpD,aAAI,iBAAM,UAAN,mBAAa,WAAb,mBAAqB,KAAK;AAC5B,gBAAM,eAAe,MAAMA,OAAa,QAAC,YAAY;AAAA,YACnD,QAAQ,MAAM,MAAM,OAAO;AAAA,YAC3B,QAAQ;AAAA,YACR,UAAU;AAAA,YACV,OAAO;AAAA,UACf,CAAO;AAGD,yBAAe,QAAQ,aAAa,OAAO,OAAK,EAAE,QAAQ,MAAM,MAAM,GAAG;AAAA,QAC/E;AAAA,MACG,SAAQ,OAAO;AACd,gBAAQ,MAAM,8BAA8B,KAAK;AAAA,MACrD,UAAY;AACR,kBAAU,QAAQ;AAAA,MACtB;AAAA,IACA;AAGAC,QAAS,UAAC,cAAc;AAExBC,QAAK,MAAC,MAAM,MAAM,OAAO,KAAK,CAAC,WAAW;AACxC,UAAI,QAAQ;AACV,uBAAgB;AAAA,MACpB;AAAA,IACA,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|