@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,174 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
|
|
3
|
+
const vue = require("vue");
|
|
4
|
+
const Field = require("../../../../components/Field/Field.vue.cjs");
|
|
5
|
+
const Radio = require("../../../../components/Radio/Radio.vue.cjs");
|
|
6
|
+
const Button = require("../../../../components/Button/Button.vue.cjs");
|
|
7
|
+
const UploadImage = require("../../../../components/UploadImage/UploadImage.vue.cjs");
|
|
8
|
+
const Media = require("../../../../components/Media/Media.vue.cjs");
|
|
9
|
+
const IconMusic = require("../../../icons/entities/IconMusic.vue.cjs");
|
|
10
|
+
const auth = require("../../../auth/views/store/auth.cjs");
|
|
11
|
+
const playlists = require("../../store/playlists.cjs");
|
|
12
|
+
const _hoisted_1 = { class: "playlist-form" };
|
|
13
|
+
const _hoisted_2 = { class: "form-group mn-b-medium" };
|
|
14
|
+
const _hoisted_3 = { class: "form-group mn-b-medium" };
|
|
15
|
+
const _hoisted_4 = { class: "form-group mn-b-medium" };
|
|
16
|
+
const _hoisted_5 = { class: "flex gap-small" };
|
|
17
|
+
const _hoisted_6 = { class: "form-group mn-b-medium" };
|
|
18
|
+
const _hoisted_7 = { class: "playlist-cover-upload flex gap-medium" };
|
|
19
|
+
const _hoisted_8 = { class: "playlist-cover-preview bg-dark-transp-25 radius-small o-hidden" };
|
|
20
|
+
const _hoisted_9 = {
|
|
21
|
+
key: 1,
|
|
22
|
+
class: "w-10r h-10r flex-center flex"
|
|
23
|
+
};
|
|
24
|
+
const _hoisted_10 = { class: "form-actions t-right" };
|
|
25
|
+
const _sfc_main = {
|
|
26
|
+
__name: "PlaylistForm",
|
|
27
|
+
emits: ["created", "cancel"],
|
|
28
|
+
setup(__props, { emit: __emit }) {
|
|
29
|
+
const emit = __emit;
|
|
30
|
+
const form = vue.reactive({
|
|
31
|
+
title: "",
|
|
32
|
+
description: "",
|
|
33
|
+
isPublic: true,
|
|
34
|
+
coverUrl: "",
|
|
35
|
+
isCollaborative: false,
|
|
36
|
+
tracks: []
|
|
37
|
+
});
|
|
38
|
+
const validationErrors = vue.reactive({});
|
|
39
|
+
const submitForm = async () => {
|
|
40
|
+
validationErrors.title = !form.title ? { message: "Playlist name is required" } : null;
|
|
41
|
+
if (Object.values(validationErrors).some((error) => error !== null)) {
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
const playlistData = {
|
|
45
|
+
...form,
|
|
46
|
+
creator: {
|
|
47
|
+
type: "User",
|
|
48
|
+
target: auth.state.user._id
|
|
49
|
+
},
|
|
50
|
+
owner: {
|
|
51
|
+
type: "User",
|
|
52
|
+
target: auth.state.user._id
|
|
53
|
+
}
|
|
54
|
+
};
|
|
55
|
+
try {
|
|
56
|
+
const playlist = await playlists.actions.createPlaylist(playlistData);
|
|
57
|
+
emit("created", playlist);
|
|
58
|
+
} catch (error) {
|
|
59
|
+
console.error("Error creating playlist:", error);
|
|
60
|
+
}
|
|
61
|
+
};
|
|
62
|
+
return (_ctx, _cache) => {
|
|
63
|
+
return vue.openBlock(), vue.createElementBlock("div", _hoisted_1, [
|
|
64
|
+
vue.createElementVNode("form", {
|
|
65
|
+
onSubmit: vue.withModifiers(submitForm, ["prevent"])
|
|
66
|
+
}, [
|
|
67
|
+
vue.createElementVNode("div", _hoisted_2, [
|
|
68
|
+
_cache[6] || (_cache[6] = vue.createElementVNode("label", {
|
|
69
|
+
for: "title",
|
|
70
|
+
class: "t-white t-medium mn-b-thin d-block"
|
|
71
|
+
}, "Playlist Name", -1)),
|
|
72
|
+
vue.createVNode(Field.default, {
|
|
73
|
+
field: form.title,
|
|
74
|
+
"onUpdate:field": _cache[0] || (_cache[0] = ($event) => form.title = $event),
|
|
75
|
+
id: "title",
|
|
76
|
+
type: "text",
|
|
77
|
+
placeholder: "New Playlist",
|
|
78
|
+
validation: validationErrors.title,
|
|
79
|
+
class: "w-100 pd-small bg-dark-transp-25 radius-small t-white"
|
|
80
|
+
}, null, 8, ["field", "validation"])
|
|
81
|
+
]),
|
|
82
|
+
vue.createElementVNode("div", _hoisted_3, [
|
|
83
|
+
_cache[7] || (_cache[7] = vue.createElementVNode("label", {
|
|
84
|
+
for: "description",
|
|
85
|
+
class: "t-white t-medium mn-b-thin d-block"
|
|
86
|
+
}, "Description", -1)),
|
|
87
|
+
vue.createVNode(Field.default, {
|
|
88
|
+
field: form.description,
|
|
89
|
+
"onUpdate:field": _cache[1] || (_cache[1] = ($event) => form.description = $event),
|
|
90
|
+
id: "description",
|
|
91
|
+
type: "textarea",
|
|
92
|
+
placeholder: "Add an optional description",
|
|
93
|
+
validation: validationErrors.description,
|
|
94
|
+
class: "w-100 pd-small bg-dark-transp-25 radius-small t-white"
|
|
95
|
+
}, null, 8, ["field", "validation"])
|
|
96
|
+
]),
|
|
97
|
+
vue.createElementVNode("div", _hoisted_4, [
|
|
98
|
+
_cache[8] || (_cache[8] = vue.createElementVNode("label", { class: "t-white t-medium mn-b-thin d-block" }, "Privacy", -1)),
|
|
99
|
+
vue.createElementVNode("div", _hoisted_5, [
|
|
100
|
+
vue.createVNode(Radio.default, {
|
|
101
|
+
radio: form.isPublic,
|
|
102
|
+
"onUpdate:radio": _cache[2] || (_cache[2] = ($event) => form.isPublic = $event),
|
|
103
|
+
value: true,
|
|
104
|
+
name: "privacy",
|
|
105
|
+
label: "Public",
|
|
106
|
+
class: "t-white"
|
|
107
|
+
}, null, 8, ["radio"]),
|
|
108
|
+
vue.createVNode(Radio.default, {
|
|
109
|
+
radio: form.isPublic,
|
|
110
|
+
"onUpdate:radio": _cache[3] || (_cache[3] = ($event) => form.isPublic = $event),
|
|
111
|
+
value: false,
|
|
112
|
+
name: "privacy",
|
|
113
|
+
label: "Private",
|
|
114
|
+
class: "t-white"
|
|
115
|
+
}, null, 8, ["radio"])
|
|
116
|
+
])
|
|
117
|
+
]),
|
|
118
|
+
vue.createElementVNode("div", _hoisted_6, [
|
|
119
|
+
_cache[9] || (_cache[9] = vue.createElementVNode("label", { class: "t-white t-medium mn-b-thin d-block" }, "Cover Image", -1)),
|
|
120
|
+
vue.createElementVNode("div", _hoisted_7, [
|
|
121
|
+
vue.createElementVNode("div", _hoisted_8, [
|
|
122
|
+
form.coverUrl ? (vue.openBlock(), vue.createBlock(Media.default, {
|
|
123
|
+
key: 0,
|
|
124
|
+
url: form.coverUrl,
|
|
125
|
+
class: "w-10r h-10r object-fit-cover"
|
|
126
|
+
}, null, 8, ["url"])) : (vue.openBlock(), vue.createElementBlock("div", _hoisted_9, [
|
|
127
|
+
vue.createVNode(IconMusic.default, {
|
|
128
|
+
class: "i-big",
|
|
129
|
+
fill: "rgb(var(--grey))"
|
|
130
|
+
})
|
|
131
|
+
]))
|
|
132
|
+
]),
|
|
133
|
+
vue.createVNode(UploadImage.default, {
|
|
134
|
+
photo: form.coverUrl,
|
|
135
|
+
"onUpdate:photo": _cache[4] || (_cache[4] = ($event) => form.coverUrl = $event),
|
|
136
|
+
uploadPath: "playlists",
|
|
137
|
+
class: "flex-1 h-10r bg-dark-transp-25 radius-small"
|
|
138
|
+
}, null, 8, ["photo"])
|
|
139
|
+
])
|
|
140
|
+
]),
|
|
141
|
+
vue.createElementVNode("div", _hoisted_10, [
|
|
142
|
+
vue.createVNode(Button.default, {
|
|
143
|
+
onClick: _cache[5] || (_cache[5] = ($event) => _ctx.$emit("cancel")),
|
|
144
|
+
type: "button",
|
|
145
|
+
class: "bg-dark-transp-25 t-white pd-small radius-small mn-r-small hover-bg-dark",
|
|
146
|
+
showLoader: false,
|
|
147
|
+
showSucces: false
|
|
148
|
+
}, {
|
|
149
|
+
default: vue.withCtx(() => _cache[10] || (_cache[10] = [
|
|
150
|
+
vue.createTextVNode(" Cancel ")
|
|
151
|
+
])),
|
|
152
|
+
_: 1
|
|
153
|
+
}),
|
|
154
|
+
vue.createVNode(Button.default, {
|
|
155
|
+
type: "submit",
|
|
156
|
+
class: "bg-main t-white pd-small radius-small hover-scale-1",
|
|
157
|
+
submit: submitForm,
|
|
158
|
+
showLoader: true,
|
|
159
|
+
showSucces: true,
|
|
160
|
+
validation: !!Object.keys(validationErrors).length
|
|
161
|
+
}, {
|
|
162
|
+
default: vue.withCtx(() => _cache[11] || (_cache[11] = [
|
|
163
|
+
vue.createTextVNode(" Create Playlist ")
|
|
164
|
+
])),
|
|
165
|
+
_: 1
|
|
166
|
+
}, 8, ["validation"])
|
|
167
|
+
])
|
|
168
|
+
], 32)
|
|
169
|
+
]);
|
|
170
|
+
};
|
|
171
|
+
}
|
|
172
|
+
};
|
|
173
|
+
exports.default = _sfc_main;
|
|
174
|
+
//# sourceMappingURL=PlaylistForm.vue.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PlaylistForm.vue.cjs","sources":["../../../../../../../src/modules/music/components/forms/PlaylistForm.vue"],"sourcesContent":["<!-- components/forms/PlaylistForm.vue -->\n<template>\n <div class=\"playlist-form\">\n <form @submit.prevent=\"submitForm\">\n <div class=\"form-group mn-b-medium\">\n <label for=\"title\" class=\"t-white t-medium mn-b-thin d-block\">Playlist Name</label>\n <Field \n v-model:field=\"form.title\"\n id=\"title\"\n type=\"text\"\n placeholder=\"New Playlist\"\n :validation=\"validationErrors.title\"\n class=\"w-100 pd-small bg-dark-transp-25 radius-small t-white\"\n />\n </div>\n \n <div class=\"form-group mn-b-medium\">\n <label for=\"description\" class=\"t-white t-medium mn-b-thin d-block\">Description</label>\n <Field \n v-model:field=\"form.description\"\n id=\"description\"\n type=\"textarea\"\n placeholder=\"Add an optional description\"\n :validation=\"validationErrors.description\"\n class=\"w-100 pd-small bg-dark-transp-25 radius-small t-white\"\n />\n </div>\n \n <div class=\"form-group mn-b-medium\">\n <label class=\"t-white t-medium mn-b-thin d-block\">Privacy</label>\n <div class=\"flex gap-small\">\n <Radio \n v-model:radio=\"form.isPublic\"\n :value=\"true\"\n name=\"privacy\"\n label=\"Public\"\n class=\"t-white\"\n />\n <Radio \n v-model:radio=\"form.isPublic\"\n :value=\"false\"\n name=\"privacy\"\n label=\"Private\"\n class=\"t-white\"\n />\n </div>\n </div>\n \n <div class=\"form-group mn-b-medium\">\n <label class=\"t-white t-medium mn-b-thin d-block\">Cover Image</label>\n <div class=\"playlist-cover-upload flex gap-medium\">\n <div class=\"playlist-cover-preview bg-dark-transp-25 radius-small o-hidden\">\n <Media \n v-if=\"form.coverUrl\"\n :url=\"form.coverUrl\"\n class=\"w-10r h-10r object-fit-cover\"\n />\n <div v-else class=\"w-10r h-10r flex-center flex\">\n <IconMusic class=\"i-big\" fill=\"rgb(var(--grey))\"/>\n </div>\n </div>\n \n <UploadImage\n v-model:photo=\"form.coverUrl\"\n uploadPath=\"playlists\"\n class=\"flex-1 h-10r bg-dark-transp-25 radius-small\"\n />\n </div>\n </div>\n \n <div class=\"form-actions t-right\">\n <Button \n @click=\"$emit('cancel')\"\n type=\"button\"\n class=\"bg-dark-transp-25 t-white pd-small radius-small mn-r-small hover-bg-dark\"\n :showLoader=\"false\" \n :showSucces=\"false\"\n >\n Cancel\n </Button>\n \n <Button \n type=\"submit\"\n class=\"bg-main t-white pd-small radius-small hover-scale-1\"\n :submit=\"submitForm\"\n :showLoader=\"true\" \n :showSucces=\"true\"\n :validation=\"!!Object.keys(validationErrors).length\"\n >\n Create Playlist\n </Button>\n </div>\n </form>\n </div>\n</template>\n\n<script setup>\nimport { ref, reactive } from 'vue';\nimport Field from '@martyrs/src/components/Field/Field.vue';\nimport Radio from '@martyrs/src/components/Radio/Radio.vue';\nimport Button from '@martyrs/src/components/Button/Button.vue';\nimport UploadImage from '@martyrs/src/components/UploadImage/UploadImage.vue';\nimport Media from '@martyrs/src/components/Media/Media.vue';\nimport IconMusic from '@martyrs/src/modules/icons/entities/IconMusic.vue';\n\n// Import auth store and playlists store\nimport { state as authState } from '@martyrs/src/modules/auth/views/store/auth.js';\nimport { actions as playlistsActions } from '../../store/playlists.js';\n\nconst emit = defineEmits(['created', 'cancel']);\n\n// Form data\nconst form = reactive({\n title: '',\n description: '',\n isPublic: true,\n coverUrl: '',\n isCollaborative: false,\n tracks: []\n});\n\n// Validation\nconst validationErrors = reactive({});\n\n// Form submission\nconst submitForm = async () => {\n // Validate form\n validationErrors.title = !form.title ? { message: 'Playlist name is required' } : null;\n \n // If there are validation errors, don't submit\n if (Object.values(validationErrors).some(error => error !== null)) {\n return;\n }\n \n // Prepare playlist data\n const playlistData = {\n ...form,\n creator: {\n type: 'User',\n target: authState.user._id\n },\n owner: {\n type: 'User',\n target: authState.user._id\n }\n };\n \n try {\n const playlist = await playlistsActions.createPlaylist(playlistData);\n emit('created', playlist);\n } catch (error) {\n console.error('Error creating playlist:', error);\n // Handle error (could add form-level error message)\n }\n};\n</script>"],"names":["reactive","authState","playlistsActions"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AA6GA,UAAM,OAAO;AAGb,UAAM,OAAOA,IAAAA,SAAS;AAAA,MACpB,OAAO;AAAA,MACP,aAAa;AAAA,MACb,UAAU;AAAA,MACV,UAAU;AAAA,MACV,iBAAiB;AAAA,MACjB,QAAQ,CAAA;AAAA,IACV,CAAC;AAGD,UAAM,mBAAmBA,IAAQ,SAAC,EAAE;AAGpC,UAAM,aAAa,YAAY;AAE7B,uBAAiB,QAAQ,CAAC,KAAK,QAAQ,EAAE,SAAS,4BAA2B,IAAK;AAGlF,UAAI,OAAO,OAAO,gBAAgB,EAAE,KAAK,WAAS,UAAU,IAAI,GAAG;AACjE;AAAA,MACJ;AAGE,YAAM,eAAe;AAAA,QACnB,GAAG;AAAA,QACH,SAAS;AAAA,UACP,MAAM;AAAA,UACN,QAAQC,KAAS,MAAC,KAAK;AAAA,QACxB;AAAA,QACD,OAAO;AAAA,UACL,MAAM;AAAA,UACN,QAAQA,KAAS,MAAC,KAAK;AAAA,QAC7B;AAAA,MACG;AAED,UAAI;AACF,cAAM,WAAW,MAAMC,kBAAiB,eAAe,YAAY;AACnE,aAAK,WAAW,QAAQ;AAAA,MACzB,SAAQ,OAAO;AACd,gBAAQ,MAAM,4BAA4B,KAAK;AAAA,MAEnD;AAAA,IACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -0,0 +1,174 @@
|
|
|
1
|
+
import { reactive, createElementBlock, openBlock, createElementVNode, withModifiers, createVNode, createBlock, withCtx, createTextVNode } from "vue";
|
|
2
|
+
import Field from "../../../../components/Field/Field.vue.js";
|
|
3
|
+
import _sfc_main$1 from "../../../../components/Radio/Radio.vue.js";
|
|
4
|
+
import _sfc_main$4 from "../../../../components/Button/Button.vue.js";
|
|
5
|
+
import _sfc_main$3 from "../../../../components/UploadImage/UploadImage.vue.js";
|
|
6
|
+
import Media from "../../../../components/Media/Media.vue.js";
|
|
7
|
+
import _sfc_main$2 from "../../../icons/entities/IconMusic.vue.js";
|
|
8
|
+
import { state } from "../../../auth/views/store/auth.js";
|
|
9
|
+
import { actions } from "../../store/playlists.js";
|
|
10
|
+
const _hoisted_1 = { class: "playlist-form" };
|
|
11
|
+
const _hoisted_2 = { class: "form-group mn-b-medium" };
|
|
12
|
+
const _hoisted_3 = { class: "form-group mn-b-medium" };
|
|
13
|
+
const _hoisted_4 = { class: "form-group mn-b-medium" };
|
|
14
|
+
const _hoisted_5 = { class: "flex gap-small" };
|
|
15
|
+
const _hoisted_6 = { class: "form-group mn-b-medium" };
|
|
16
|
+
const _hoisted_7 = { class: "playlist-cover-upload flex gap-medium" };
|
|
17
|
+
const _hoisted_8 = { class: "playlist-cover-preview bg-dark-transp-25 radius-small o-hidden" };
|
|
18
|
+
const _hoisted_9 = {
|
|
19
|
+
key: 1,
|
|
20
|
+
class: "w-10r h-10r flex-center flex"
|
|
21
|
+
};
|
|
22
|
+
const _hoisted_10 = { class: "form-actions t-right" };
|
|
23
|
+
const _sfc_main = {
|
|
24
|
+
__name: "PlaylistForm",
|
|
25
|
+
emits: ["created", "cancel"],
|
|
26
|
+
setup(__props, { emit: __emit }) {
|
|
27
|
+
const emit = __emit;
|
|
28
|
+
const form = reactive({
|
|
29
|
+
title: "",
|
|
30
|
+
description: "",
|
|
31
|
+
isPublic: true,
|
|
32
|
+
coverUrl: "",
|
|
33
|
+
isCollaborative: false,
|
|
34
|
+
tracks: []
|
|
35
|
+
});
|
|
36
|
+
const validationErrors = reactive({});
|
|
37
|
+
const submitForm = async () => {
|
|
38
|
+
validationErrors.title = !form.title ? { message: "Playlist name is required" } : null;
|
|
39
|
+
if (Object.values(validationErrors).some((error) => error !== null)) {
|
|
40
|
+
return;
|
|
41
|
+
}
|
|
42
|
+
const playlistData = {
|
|
43
|
+
...form,
|
|
44
|
+
creator: {
|
|
45
|
+
type: "User",
|
|
46
|
+
target: state.user._id
|
|
47
|
+
},
|
|
48
|
+
owner: {
|
|
49
|
+
type: "User",
|
|
50
|
+
target: state.user._id
|
|
51
|
+
}
|
|
52
|
+
};
|
|
53
|
+
try {
|
|
54
|
+
const playlist = await actions.createPlaylist(playlistData);
|
|
55
|
+
emit("created", playlist);
|
|
56
|
+
} catch (error) {
|
|
57
|
+
console.error("Error creating playlist:", error);
|
|
58
|
+
}
|
|
59
|
+
};
|
|
60
|
+
return (_ctx, _cache) => {
|
|
61
|
+
return openBlock(), createElementBlock("div", _hoisted_1, [
|
|
62
|
+
createElementVNode("form", {
|
|
63
|
+
onSubmit: withModifiers(submitForm, ["prevent"])
|
|
64
|
+
}, [
|
|
65
|
+
createElementVNode("div", _hoisted_2, [
|
|
66
|
+
_cache[6] || (_cache[6] = createElementVNode("label", {
|
|
67
|
+
for: "title",
|
|
68
|
+
class: "t-white t-medium mn-b-thin d-block"
|
|
69
|
+
}, "Playlist Name", -1)),
|
|
70
|
+
createVNode(Field, {
|
|
71
|
+
field: form.title,
|
|
72
|
+
"onUpdate:field": _cache[0] || (_cache[0] = ($event) => form.title = $event),
|
|
73
|
+
id: "title",
|
|
74
|
+
type: "text",
|
|
75
|
+
placeholder: "New Playlist",
|
|
76
|
+
validation: validationErrors.title,
|
|
77
|
+
class: "w-100 pd-small bg-dark-transp-25 radius-small t-white"
|
|
78
|
+
}, null, 8, ["field", "validation"])
|
|
79
|
+
]),
|
|
80
|
+
createElementVNode("div", _hoisted_3, [
|
|
81
|
+
_cache[7] || (_cache[7] = createElementVNode("label", {
|
|
82
|
+
for: "description",
|
|
83
|
+
class: "t-white t-medium mn-b-thin d-block"
|
|
84
|
+
}, "Description", -1)),
|
|
85
|
+
createVNode(Field, {
|
|
86
|
+
field: form.description,
|
|
87
|
+
"onUpdate:field": _cache[1] || (_cache[1] = ($event) => form.description = $event),
|
|
88
|
+
id: "description",
|
|
89
|
+
type: "textarea",
|
|
90
|
+
placeholder: "Add an optional description",
|
|
91
|
+
validation: validationErrors.description,
|
|
92
|
+
class: "w-100 pd-small bg-dark-transp-25 radius-small t-white"
|
|
93
|
+
}, null, 8, ["field", "validation"])
|
|
94
|
+
]),
|
|
95
|
+
createElementVNode("div", _hoisted_4, [
|
|
96
|
+
_cache[8] || (_cache[8] = createElementVNode("label", { class: "t-white t-medium mn-b-thin d-block" }, "Privacy", -1)),
|
|
97
|
+
createElementVNode("div", _hoisted_5, [
|
|
98
|
+
createVNode(_sfc_main$1, {
|
|
99
|
+
radio: form.isPublic,
|
|
100
|
+
"onUpdate:radio": _cache[2] || (_cache[2] = ($event) => form.isPublic = $event),
|
|
101
|
+
value: true,
|
|
102
|
+
name: "privacy",
|
|
103
|
+
label: "Public",
|
|
104
|
+
class: "t-white"
|
|
105
|
+
}, null, 8, ["radio"]),
|
|
106
|
+
createVNode(_sfc_main$1, {
|
|
107
|
+
radio: form.isPublic,
|
|
108
|
+
"onUpdate:radio": _cache[3] || (_cache[3] = ($event) => form.isPublic = $event),
|
|
109
|
+
value: false,
|
|
110
|
+
name: "privacy",
|
|
111
|
+
label: "Private",
|
|
112
|
+
class: "t-white"
|
|
113
|
+
}, null, 8, ["radio"])
|
|
114
|
+
])
|
|
115
|
+
]),
|
|
116
|
+
createElementVNode("div", _hoisted_6, [
|
|
117
|
+
_cache[9] || (_cache[9] = createElementVNode("label", { class: "t-white t-medium mn-b-thin d-block" }, "Cover Image", -1)),
|
|
118
|
+
createElementVNode("div", _hoisted_7, [
|
|
119
|
+
createElementVNode("div", _hoisted_8, [
|
|
120
|
+
form.coverUrl ? (openBlock(), createBlock(Media, {
|
|
121
|
+
key: 0,
|
|
122
|
+
url: form.coverUrl,
|
|
123
|
+
class: "w-10r h-10r object-fit-cover"
|
|
124
|
+
}, null, 8, ["url"])) : (openBlock(), createElementBlock("div", _hoisted_9, [
|
|
125
|
+
createVNode(_sfc_main$2, {
|
|
126
|
+
class: "i-big",
|
|
127
|
+
fill: "rgb(var(--grey))"
|
|
128
|
+
})
|
|
129
|
+
]))
|
|
130
|
+
]),
|
|
131
|
+
createVNode(_sfc_main$3, {
|
|
132
|
+
photo: form.coverUrl,
|
|
133
|
+
"onUpdate:photo": _cache[4] || (_cache[4] = ($event) => form.coverUrl = $event),
|
|
134
|
+
uploadPath: "playlists",
|
|
135
|
+
class: "flex-1 h-10r bg-dark-transp-25 radius-small"
|
|
136
|
+
}, null, 8, ["photo"])
|
|
137
|
+
])
|
|
138
|
+
]),
|
|
139
|
+
createElementVNode("div", _hoisted_10, [
|
|
140
|
+
createVNode(_sfc_main$4, {
|
|
141
|
+
onClick: _cache[5] || (_cache[5] = ($event) => _ctx.$emit("cancel")),
|
|
142
|
+
type: "button",
|
|
143
|
+
class: "bg-dark-transp-25 t-white pd-small radius-small mn-r-small hover-bg-dark",
|
|
144
|
+
showLoader: false,
|
|
145
|
+
showSucces: false
|
|
146
|
+
}, {
|
|
147
|
+
default: withCtx(() => _cache[10] || (_cache[10] = [
|
|
148
|
+
createTextVNode(" Cancel ")
|
|
149
|
+
])),
|
|
150
|
+
_: 1
|
|
151
|
+
}),
|
|
152
|
+
createVNode(_sfc_main$4, {
|
|
153
|
+
type: "submit",
|
|
154
|
+
class: "bg-main t-white pd-small radius-small hover-scale-1",
|
|
155
|
+
submit: submitForm,
|
|
156
|
+
showLoader: true,
|
|
157
|
+
showSucces: true,
|
|
158
|
+
validation: !!Object.keys(validationErrors).length
|
|
159
|
+
}, {
|
|
160
|
+
default: withCtx(() => _cache[11] || (_cache[11] = [
|
|
161
|
+
createTextVNode(" Create Playlist ")
|
|
162
|
+
])),
|
|
163
|
+
_: 1
|
|
164
|
+
}, 8, ["validation"])
|
|
165
|
+
])
|
|
166
|
+
], 32)
|
|
167
|
+
]);
|
|
168
|
+
};
|
|
169
|
+
}
|
|
170
|
+
};
|
|
171
|
+
export {
|
|
172
|
+
_sfc_main as default
|
|
173
|
+
};
|
|
174
|
+
//# sourceMappingURL=PlaylistForm.vue.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PlaylistForm.vue.js","sources":["../../../../../../../src/modules/music/components/forms/PlaylistForm.vue"],"sourcesContent":["<!-- components/forms/PlaylistForm.vue -->\n<template>\n <div class=\"playlist-form\">\n <form @submit.prevent=\"submitForm\">\n <div class=\"form-group mn-b-medium\">\n <label for=\"title\" class=\"t-white t-medium mn-b-thin d-block\">Playlist Name</label>\n <Field \n v-model:field=\"form.title\"\n id=\"title\"\n type=\"text\"\n placeholder=\"New Playlist\"\n :validation=\"validationErrors.title\"\n class=\"w-100 pd-small bg-dark-transp-25 radius-small t-white\"\n />\n </div>\n \n <div class=\"form-group mn-b-medium\">\n <label for=\"description\" class=\"t-white t-medium mn-b-thin d-block\">Description</label>\n <Field \n v-model:field=\"form.description\"\n id=\"description\"\n type=\"textarea\"\n placeholder=\"Add an optional description\"\n :validation=\"validationErrors.description\"\n class=\"w-100 pd-small bg-dark-transp-25 radius-small t-white\"\n />\n </div>\n \n <div class=\"form-group mn-b-medium\">\n <label class=\"t-white t-medium mn-b-thin d-block\">Privacy</label>\n <div class=\"flex gap-small\">\n <Radio \n v-model:radio=\"form.isPublic\"\n :value=\"true\"\n name=\"privacy\"\n label=\"Public\"\n class=\"t-white\"\n />\n <Radio \n v-model:radio=\"form.isPublic\"\n :value=\"false\"\n name=\"privacy\"\n label=\"Private\"\n class=\"t-white\"\n />\n </div>\n </div>\n \n <div class=\"form-group mn-b-medium\">\n <label class=\"t-white t-medium mn-b-thin d-block\">Cover Image</label>\n <div class=\"playlist-cover-upload flex gap-medium\">\n <div class=\"playlist-cover-preview bg-dark-transp-25 radius-small o-hidden\">\n <Media \n v-if=\"form.coverUrl\"\n :url=\"form.coverUrl\"\n class=\"w-10r h-10r object-fit-cover\"\n />\n <div v-else class=\"w-10r h-10r flex-center flex\">\n <IconMusic class=\"i-big\" fill=\"rgb(var(--grey))\"/>\n </div>\n </div>\n \n <UploadImage\n v-model:photo=\"form.coverUrl\"\n uploadPath=\"playlists\"\n class=\"flex-1 h-10r bg-dark-transp-25 radius-small\"\n />\n </div>\n </div>\n \n <div class=\"form-actions t-right\">\n <Button \n @click=\"$emit('cancel')\"\n type=\"button\"\n class=\"bg-dark-transp-25 t-white pd-small radius-small mn-r-small hover-bg-dark\"\n :showLoader=\"false\" \n :showSucces=\"false\"\n >\n Cancel\n </Button>\n \n <Button \n type=\"submit\"\n class=\"bg-main t-white pd-small radius-small hover-scale-1\"\n :submit=\"submitForm\"\n :showLoader=\"true\" \n :showSucces=\"true\"\n :validation=\"!!Object.keys(validationErrors).length\"\n >\n Create Playlist\n </Button>\n </div>\n </form>\n </div>\n</template>\n\n<script setup>\nimport { ref, reactive } from 'vue';\nimport Field from '@martyrs/src/components/Field/Field.vue';\nimport Radio from '@martyrs/src/components/Radio/Radio.vue';\nimport Button from '@martyrs/src/components/Button/Button.vue';\nimport UploadImage from '@martyrs/src/components/UploadImage/UploadImage.vue';\nimport Media from '@martyrs/src/components/Media/Media.vue';\nimport IconMusic from '@martyrs/src/modules/icons/entities/IconMusic.vue';\n\n// Import auth store and playlists store\nimport { state as authState } from '@martyrs/src/modules/auth/views/store/auth.js';\nimport { actions as playlistsActions } from '../../store/playlists.js';\n\nconst emit = defineEmits(['created', 'cancel']);\n\n// Form data\nconst form = reactive({\n title: '',\n description: '',\n isPublic: true,\n coverUrl: '',\n isCollaborative: false,\n tracks: []\n});\n\n// Validation\nconst validationErrors = reactive({});\n\n// Form submission\nconst submitForm = async () => {\n // Validate form\n validationErrors.title = !form.title ? { message: 'Playlist name is required' } : null;\n \n // If there are validation errors, don't submit\n if (Object.values(validationErrors).some(error => error !== null)) {\n return;\n }\n \n // Prepare playlist data\n const playlistData = {\n ...form,\n creator: {\n type: 'User',\n target: authState.user._id\n },\n owner: {\n type: 'User',\n target: authState.user._id\n }\n };\n \n try {\n const playlist = await playlistsActions.createPlaylist(playlistData);\n emit('created', playlist);\n } catch (error) {\n console.error('Error creating playlist:', error);\n // Handle error (could add form-level error message)\n }\n};\n</script>"],"names":["authState","playlistsActions"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AA6GA,UAAM,OAAO;AAGb,UAAM,OAAO,SAAS;AAAA,MACpB,OAAO;AAAA,MACP,aAAa;AAAA,MACb,UAAU;AAAA,MACV,UAAU;AAAA,MACV,iBAAiB;AAAA,MACjB,QAAQ,CAAA;AAAA,IACV,CAAC;AAGD,UAAM,mBAAmB,SAAS,EAAE;AAGpC,UAAM,aAAa,YAAY;AAE7B,uBAAiB,QAAQ,CAAC,KAAK,QAAQ,EAAE,SAAS,4BAA2B,IAAK;AAGlF,UAAI,OAAO,OAAO,gBAAgB,EAAE,KAAK,WAAS,UAAU,IAAI,GAAG;AACjE;AAAA,MACJ;AAGE,YAAM,eAAe;AAAA,QACnB,GAAG;AAAA,QACH,SAAS;AAAA,UACP,MAAM;AAAA,UACN,QAAQA,MAAU,KAAK;AAAA,QACxB;AAAA,QACD,OAAO;AAAA,UACL,MAAM;AAAA,UACN,QAAQA,MAAU,KAAK;AAAA,QAC7B;AAAA,MACG;AAED,UAAI;AACF,cAAM,WAAW,MAAMC,QAAiB,eAAe,YAAY;AACnE,aAAK,WAAW,QAAQ;AAAA,MACzB,SAAQ,OAAO;AACd,gBAAQ,MAAM,4BAA4B,KAAK;AAAA,MAEnD;AAAA,IACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
|
|
3
|
+
const vue = require("vue");
|
|
4
|
+
const Button = require("../../../../components/Button/Button.vue.cjs");
|
|
5
|
+
const IconSearch = require("../../../icons/navigation/IconSearch.vue.cjs");
|
|
6
|
+
const IconCross = require("../../../icons/navigation/IconCross.vue.cjs");
|
|
7
|
+
const _pluginVue_exportHelper = require("../../../../../../_virtual/_plugin-vue_export-helper.cjs");
|
|
8
|
+
const _hoisted_1 = { class: "search-form flex-v-center flex bg-dark-transp-50 pd-thin radius-extra" };
|
|
9
|
+
const _hoisted_2 = ["placeholder"];
|
|
10
|
+
const _sfc_main = {
|
|
11
|
+
__name: "SearchForm",
|
|
12
|
+
props: {
|
|
13
|
+
placeholder: {
|
|
14
|
+
type: String,
|
|
15
|
+
default: "Search..."
|
|
16
|
+
},
|
|
17
|
+
initialQuery: {
|
|
18
|
+
type: String,
|
|
19
|
+
default: ""
|
|
20
|
+
}
|
|
21
|
+
},
|
|
22
|
+
emits: ["search"],
|
|
23
|
+
setup(__props, { emit: __emit }) {
|
|
24
|
+
const props = __props;
|
|
25
|
+
const emit = __emit;
|
|
26
|
+
const searchInput = vue.ref(null);
|
|
27
|
+
const searchQuery = vue.ref(props.initialQuery);
|
|
28
|
+
const handleSearch = () => {
|
|
29
|
+
if (searchQuery.value.trim()) {
|
|
30
|
+
emit("search", searchQuery.value.trim());
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
const clearSearch = () => {
|
|
34
|
+
searchQuery.value = "";
|
|
35
|
+
searchInput.value.focus();
|
|
36
|
+
};
|
|
37
|
+
vue.watchEffect(() => {
|
|
38
|
+
if (props.initialQuery !== searchQuery.value) {
|
|
39
|
+
searchQuery.value = props.initialQuery;
|
|
40
|
+
}
|
|
41
|
+
});
|
|
42
|
+
return (_ctx, _cache) => {
|
|
43
|
+
return vue.openBlock(), vue.createElementBlock("div", _hoisted_1, [
|
|
44
|
+
vue.createVNode(IconSearch.default, {
|
|
45
|
+
class: "i-small mn-r-small",
|
|
46
|
+
fill: "rgb(var(--grey))"
|
|
47
|
+
}),
|
|
48
|
+
vue.withDirectives(vue.createElementVNode("input", {
|
|
49
|
+
ref_key: "searchInput",
|
|
50
|
+
ref: searchInput,
|
|
51
|
+
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => searchQuery.value = $event),
|
|
52
|
+
type: "text",
|
|
53
|
+
placeholder: __props.placeholder,
|
|
54
|
+
class: "bg-transparent border-none t-white flex-1",
|
|
55
|
+
onKeydown: vue.withKeys(handleSearch, ["enter"])
|
|
56
|
+
}, null, 40, _hoisted_2), [
|
|
57
|
+
[vue.vModelText, searchQuery.value]
|
|
58
|
+
]),
|
|
59
|
+
searchQuery.value.length > 0 ? (vue.openBlock(), vue.createBlock(Button.default, {
|
|
60
|
+
key: 0,
|
|
61
|
+
onClick: clearSearch,
|
|
62
|
+
class: "bg-transparent border-none pd-zero",
|
|
63
|
+
showLoader: false,
|
|
64
|
+
showSucces: false
|
|
65
|
+
}, {
|
|
66
|
+
default: vue.withCtx(() => [
|
|
67
|
+
vue.createVNode(IconCross.default, {
|
|
68
|
+
class: "i-small",
|
|
69
|
+
fill: "rgb(var(--grey))"
|
|
70
|
+
})
|
|
71
|
+
]),
|
|
72
|
+
_: 1
|
|
73
|
+
})) : vue.createCommentVNode("", true)
|
|
74
|
+
]);
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
};
|
|
78
|
+
const SearchForm = /* @__PURE__ */ _pluginVue_exportHelper.default(_sfc_main, [["__scopeId", "data-v-3fb14bb9"]]);
|
|
79
|
+
exports.default = SearchForm;
|
|
80
|
+
//# sourceMappingURL=SearchForm.vue.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SearchForm.vue.cjs","sources":["../../../../../../../src/modules/music/components/forms/SearchForm.vue"],"sourcesContent":["<!-- components/forms/SearchForm.vue -->\n<template>\n <div class=\"search-form flex-v-center flex bg-dark-transp-50 pd-thin radius-extra\">\n <IconSearch class=\"i-small mn-r-small\" fill=\"rgb(var(--grey))\"/>\n <input \n ref=\"searchInput\"\n v-model=\"searchQuery\"\n type=\"text\"\n :placeholder=\"placeholder\"\n class=\"bg-transparent border-none t-white flex-1\"\n @keydown.enter=\"handleSearch\"\n />\n <Button \n v-if=\"searchQuery.length > 0\"\n @click=\"clearSearch\"\n class=\"bg-transparent border-none pd-zero\"\n :showLoader=\"false\" \n :showSucces=\"false\"\n >\n <IconCross class=\"i-small\" fill=\"rgb(var(--grey))\"/>\n </Button>\n </div>\n</template>\n\n<script setup>\nimport { ref, watchEffect, defineEmits } from 'vue';\nimport Button from '@martyrs/src/components/Button/Button.vue';\nimport IconSearch from '@martyrs/src/modules/icons/navigation/IconSearch.vue';\nimport IconCross from '@martyrs/src/modules/icons/navigation/IconCross.vue';\n\nconst props = defineProps({\n placeholder: {\n type: String,\n default: 'Search...'\n },\n initialQuery: {\n type: String,\n default: ''\n }\n});\n\nconst emit = defineEmits(['search']);\n\nconst searchInput = ref(null);\nconst searchQuery = ref(props.initialQuery);\n\nconst handleSearch = () => {\n if (searchQuery.value.trim()) {\n emit('search', searchQuery.value.trim());\n }\n};\n\nconst clearSearch = () => {\n searchQuery.value = '';\n searchInput.value.focus();\n};\n\nwatchEffect(() => {\n // Update search query when initialQuery prop changes\n if (props.initialQuery !== searchQuery.value) {\n searchQuery.value = props.initialQuery;\n }\n});\n</script>\n\n<style scoped>\n.search-form {\n transition: background-color 0.2s ease;\n}\n\n.search-form:focus-within {\n background-color: rgba(var(--dark), 0.8);\n}\n\ninput::placeholder {\n color: rgba(var(--grey), 0.8);\n}\n\ninput:focus {\n outline: none;\n}\n</style>"],"names":["ref","watchEffect"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AA8BA,UAAM,QAAQ;AAWd,UAAM,OAAO;AAEb,UAAM,cAAcA,IAAG,IAAC,IAAI;AAC5B,UAAM,cAAcA,IAAAA,IAAI,MAAM,YAAY;AAE1C,UAAM,eAAe,MAAM;AACzB,UAAI,YAAY,MAAM,QAAQ;AAC5B,aAAK,UAAU,YAAY,MAAM,KAAI,CAAE;AAAA,MAC3C;AAAA,IACA;AAEA,UAAM,cAAc,MAAM;AACxB,kBAAY,QAAQ;AACpB,kBAAY,MAAM,MAAO;AAAA,IAC3B;AAEAC,QAAAA,YAAY,MAAM;AAEhB,UAAI,MAAM,iBAAiB,YAAY,OAAO;AAC5C,oBAAY,QAAQ,MAAM;AAAA,MAC9B;AAAA,IACA,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
import { ref, watchEffect, createElementBlock, openBlock, createVNode, withDirectives, createBlock, createCommentVNode, createElementVNode, withKeys, vModelText, withCtx } from "vue";
|
|
2
|
+
import _sfc_main$2 from "../../../../components/Button/Button.vue.js";
|
|
3
|
+
import _sfc_main$1 from "../../../icons/navigation/IconSearch.vue.js";
|
|
4
|
+
import _sfc_main$3 from "../../../icons/navigation/IconCross.vue.js";
|
|
5
|
+
import _export_sfc from "../../../../../../_virtual/_plugin-vue_export-helper.js";
|
|
6
|
+
const _hoisted_1 = { class: "search-form flex-v-center flex bg-dark-transp-50 pd-thin radius-extra" };
|
|
7
|
+
const _hoisted_2 = ["placeholder"];
|
|
8
|
+
const _sfc_main = {
|
|
9
|
+
__name: "SearchForm",
|
|
10
|
+
props: {
|
|
11
|
+
placeholder: {
|
|
12
|
+
type: String,
|
|
13
|
+
default: "Search..."
|
|
14
|
+
},
|
|
15
|
+
initialQuery: {
|
|
16
|
+
type: String,
|
|
17
|
+
default: ""
|
|
18
|
+
}
|
|
19
|
+
},
|
|
20
|
+
emits: ["search"],
|
|
21
|
+
setup(__props, { emit: __emit }) {
|
|
22
|
+
const props = __props;
|
|
23
|
+
const emit = __emit;
|
|
24
|
+
const searchInput = ref(null);
|
|
25
|
+
const searchQuery = ref(props.initialQuery);
|
|
26
|
+
const handleSearch = () => {
|
|
27
|
+
if (searchQuery.value.trim()) {
|
|
28
|
+
emit("search", searchQuery.value.trim());
|
|
29
|
+
}
|
|
30
|
+
};
|
|
31
|
+
const clearSearch = () => {
|
|
32
|
+
searchQuery.value = "";
|
|
33
|
+
searchInput.value.focus();
|
|
34
|
+
};
|
|
35
|
+
watchEffect(() => {
|
|
36
|
+
if (props.initialQuery !== searchQuery.value) {
|
|
37
|
+
searchQuery.value = props.initialQuery;
|
|
38
|
+
}
|
|
39
|
+
});
|
|
40
|
+
return (_ctx, _cache) => {
|
|
41
|
+
return openBlock(), createElementBlock("div", _hoisted_1, [
|
|
42
|
+
createVNode(_sfc_main$1, {
|
|
43
|
+
class: "i-small mn-r-small",
|
|
44
|
+
fill: "rgb(var(--grey))"
|
|
45
|
+
}),
|
|
46
|
+
withDirectives(createElementVNode("input", {
|
|
47
|
+
ref_key: "searchInput",
|
|
48
|
+
ref: searchInput,
|
|
49
|
+
"onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => searchQuery.value = $event),
|
|
50
|
+
type: "text",
|
|
51
|
+
placeholder: __props.placeholder,
|
|
52
|
+
class: "bg-transparent border-none t-white flex-1",
|
|
53
|
+
onKeydown: withKeys(handleSearch, ["enter"])
|
|
54
|
+
}, null, 40, _hoisted_2), [
|
|
55
|
+
[vModelText, searchQuery.value]
|
|
56
|
+
]),
|
|
57
|
+
searchQuery.value.length > 0 ? (openBlock(), createBlock(_sfc_main$2, {
|
|
58
|
+
key: 0,
|
|
59
|
+
onClick: clearSearch,
|
|
60
|
+
class: "bg-transparent border-none pd-zero",
|
|
61
|
+
showLoader: false,
|
|
62
|
+
showSucces: false
|
|
63
|
+
}, {
|
|
64
|
+
default: withCtx(() => [
|
|
65
|
+
createVNode(_sfc_main$3, {
|
|
66
|
+
class: "i-small",
|
|
67
|
+
fill: "rgb(var(--grey))"
|
|
68
|
+
})
|
|
69
|
+
]),
|
|
70
|
+
_: 1
|
|
71
|
+
})) : createCommentVNode("", true)
|
|
72
|
+
]);
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
};
|
|
76
|
+
const SearchForm = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-3fb14bb9"]]);
|
|
77
|
+
export {
|
|
78
|
+
SearchForm as default
|
|
79
|
+
};
|
|
80
|
+
//# sourceMappingURL=SearchForm.vue.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SearchForm.vue.js","sources":["../../../../../../../src/modules/music/components/forms/SearchForm.vue"],"sourcesContent":["<!-- components/forms/SearchForm.vue -->\n<template>\n <div class=\"search-form flex-v-center flex bg-dark-transp-50 pd-thin radius-extra\">\n <IconSearch class=\"i-small mn-r-small\" fill=\"rgb(var(--grey))\"/>\n <input \n ref=\"searchInput\"\n v-model=\"searchQuery\"\n type=\"text\"\n :placeholder=\"placeholder\"\n class=\"bg-transparent border-none t-white flex-1\"\n @keydown.enter=\"handleSearch\"\n />\n <Button \n v-if=\"searchQuery.length > 0\"\n @click=\"clearSearch\"\n class=\"bg-transparent border-none pd-zero\"\n :showLoader=\"false\" \n :showSucces=\"false\"\n >\n <IconCross class=\"i-small\" fill=\"rgb(var(--grey))\"/>\n </Button>\n </div>\n</template>\n\n<script setup>\nimport { ref, watchEffect, defineEmits } from 'vue';\nimport Button from '@martyrs/src/components/Button/Button.vue';\nimport IconSearch from '@martyrs/src/modules/icons/navigation/IconSearch.vue';\nimport IconCross from '@martyrs/src/modules/icons/navigation/IconCross.vue';\n\nconst props = defineProps({\n placeholder: {\n type: String,\n default: 'Search...'\n },\n initialQuery: {\n type: String,\n default: ''\n }\n});\n\nconst emit = defineEmits(['search']);\n\nconst searchInput = ref(null);\nconst searchQuery = ref(props.initialQuery);\n\nconst handleSearch = () => {\n if (searchQuery.value.trim()) {\n emit('search', searchQuery.value.trim());\n }\n};\n\nconst clearSearch = () => {\n searchQuery.value = '';\n searchInput.value.focus();\n};\n\nwatchEffect(() => {\n // Update search query when initialQuery prop changes\n if (props.initialQuery !== searchQuery.value) {\n searchQuery.value = props.initialQuery;\n }\n});\n</script>\n\n<style scoped>\n.search-form {\n transition: background-color 0.2s ease;\n}\n\n.search-form:focus-within {\n background-color: rgba(var(--dark), 0.8);\n}\n\ninput::placeholder {\n color: rgba(var(--grey), 0.8);\n}\n\ninput:focus {\n outline: none;\n}\n</style>"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;AA8BA,UAAM,QAAQ;AAWd,UAAM,OAAO;AAEb,UAAM,cAAc,IAAI,IAAI;AAC5B,UAAM,cAAc,IAAI,MAAM,YAAY;AAE1C,UAAM,eAAe,MAAM;AACzB,UAAI,YAAY,MAAM,QAAQ;AAC5B,aAAK,UAAU,YAAY,MAAM,KAAI,CAAE;AAAA,MAC3C;AAAA,IACA;AAEA,UAAM,cAAc,MAAM;AACxB,kBAAY,QAAQ;AACpB,kBAAY,MAAM,MAAO;AAAA,IAC3B;AAEA,gBAAY,MAAM;AAEhB,UAAI,MAAM,iBAAiB,YAAY,OAAO;AAC5C,oBAAY,QAAQ,MAAM;AAAA,MAC9B;AAAA,IACA,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|