@ozdao/martyrs 0.2.485 → 0.2.487
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-B2jWzwLB.cjs +1 -0
- package/dist/{Media-DlUBwVWs.js → Media-DZ5_ItXQ.js} +3 -3
- 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 +3 -24
- package/dist/auth.server.js +2 -23
- package/dist/{authJwt-DBB51Iql.cjs → authJwt-D35KyJlE.cjs} +31 -2
- package/dist/{authJwt-DcYNNwcr.js → authJwt-DqxhUym0.js} +31 -2
- package/dist/chats.server.cjs +1 -1
- package/dist/chats.server.js +1 -1
- package/dist/community.server.cjs +1 -1
- package/dist/community.server.js +1 -1
- package/dist/crud-BDIArc5A.cjs +1096 -0
- package/dist/crud-DJvpe0aZ.js +1097 -0
- package/dist/events.server.cjs +1 -1
- package/dist/events.server.js +1 -1
- package/dist/files.server.cjs +1 -1
- package/dist/files.server.js +1 -1
- package/dist/gallery.server.cjs +1 -1
- package/dist/gallery.server.js +1 -1
- 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/{index-CsJwdsBW.js → index-CVuQC4k1.js} +1 -1
- package/dist/{index-YNOkL1mu.cjs → index-DiSKVCaA.cjs} +1 -1
- package/dist/main-C6_DPWGX.cjs +11 -0
- package/dist/{main-CK6rC5Sz.js → main-nQmkbWsW.js} +2291 -2224
- 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/Chips/{Chips.vue2.cjs → Chips.vue.cjs} +2 -2
- package/dist/martyrs/src/components/Chips/Chips.vue.cjs.map +1 -0
- package/dist/martyrs/src/components/Chips/{Chips.vue2.js → Chips.vue.js} +2 -2
- package/dist/martyrs/src/components/Chips/Chips.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/Field/{Field.vue.cjs → Field.vue2.cjs} +5 -6
- package/dist/martyrs/src/components/Field/Field.vue2.cjs.map +1 -0
- package/dist/martyrs/src/components/Field/{Field.vue.js → Field.vue2.js} +5 -6
- package/dist/martyrs/src/components/Field/Field.vue2.js.map +1 -0
- package/dist/martyrs/src/components/FieldBig/FieldBig.vue.cjs +10 -9
- package/dist/martyrs/src/components/FieldBig/FieldBig.vue.cjs.map +1 -1
- package/dist/martyrs/src/components/FieldBig/FieldBig.vue.js +13 -12
- package/dist/martyrs/src/components/FieldBig/FieldBig.vue.js.map +1 -1
- package/dist/martyrs/src/components/FieldPhone/FieldPhone.vue.cjs +1 -1
- package/dist/martyrs/src/components/FieldPhone/FieldPhone.vue.cjs.map +1 -1
- package/dist/martyrs/src/components/FieldPhone/FieldPhone.vue.js +1 -1
- package/dist/martyrs/src/components/FieldPhone/FieldPhone.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/Media/Media.vue.cjs +2 -2
- package/dist/martyrs/src/components/Media/Media.vue.cjs.map +1 -1
- package/dist/martyrs/src/components/Media/Media.vue.js +2 -2
- package/dist/martyrs/src/components/Media/Media.vue.js.map +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/components/Select/Select.vue.cjs +2 -2
- package/dist/martyrs/src/components/Select/Select.vue.cjs.map +1 -1
- package/dist/martyrs/src/components/Select/Select.vue.js +2 -2
- package/dist/martyrs/src/components/Select/Select.vue.js.map +1 -1
- package/dist/martyrs/src/modules/auth/views/components/pages/EnterCode.vue.cjs +1 -0
- package/dist/martyrs/src/modules/auth/views/components/pages/EnterCode.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/auth/views/components/pages/EnterCode.vue.js +1 -0
- package/dist/martyrs/src/modules/auth/views/components/pages/EnterCode.vue.js.map +1 -1
- package/dist/martyrs/src/modules/auth/views/components/pages/EnterPassword.vue.cjs +2 -2
- package/dist/martyrs/src/modules/auth/views/components/pages/EnterPassword.vue.js +5 -5
- package/dist/martyrs/src/modules/auth/views/components/pages/Invite.vue.cjs +2 -2
- package/dist/martyrs/src/modules/auth/views/components/pages/Invite.vue.js +5 -5
- package/dist/martyrs/src/modules/auth/views/components/pages/Profile.vue.cjs +3 -2
- package/dist/martyrs/src/modules/auth/views/components/pages/Profile.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/auth/views/components/pages/Profile.vue.js +3 -2
- package/dist/martyrs/src/modules/auth/views/components/pages/Profile.vue.js.map +1 -1
- 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 +2 -2
- package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditProfile.vue.js +10 -10
- package/dist/martyrs/src/modules/auth/views/components/pages/ResetPassword.vue.cjs +2 -2
- package/dist/martyrs/src/modules/auth/views/components/pages/ResetPassword.vue.js +4 -4
- package/dist/martyrs/src/modules/auth/views/components/pages/SignIn.vue.cjs +2 -2
- package/dist/martyrs/src/modules/auth/views/components/pages/SignIn.vue.js +5 -5
- package/dist/martyrs/src/modules/auth/views/components/pages/SignUp.vue.cjs +2 -2
- package/dist/martyrs/src/modules/auth/views/components/pages/SignUp.vue.js +4 -4
- package/dist/martyrs/src/modules/auth/views/components/sections/ProfileEditCredentials.vue.cjs +2 -2
- package/dist/martyrs/src/modules/auth/views/components/sections/ProfileEditCredentials.vue.js +23 -23
- package/dist/martyrs/src/modules/community/components/blocks/CardBlogpost.vue.cjs +1 -1
- package/dist/martyrs/src/modules/community/components/blocks/CardBlogpost.vue.js +1 -1
- package/dist/martyrs/src/modules/community/components/pages/BlogPost.vue.cjs +3 -3
- package/dist/martyrs/src/modules/community/components/pages/BlogPost.vue.js +3 -3
- package/dist/martyrs/src/modules/community/components/pages/CreateBlogPost.vue.cjs +4 -4
- package/dist/martyrs/src/modules/community/components/pages/CreateBlogPost.vue.js +13 -13
- package/dist/martyrs/src/modules/constructor/components/elements/Card.vue.cjs +1 -1
- package/dist/martyrs/src/modules/constructor/components/elements/Card.vue.js +3 -3
- package/dist/martyrs/src/modules/constructor/components/elements/Embed.vue.cjs +1 -1
- package/dist/martyrs/src/modules/constructor/components/elements/Embed.vue.js +2 -2
- package/dist/martyrs/src/modules/events/components/blocks/CardEvent.vue.cjs +1 -1
- package/dist/martyrs/src/modules/events/components/blocks/CardEvent.vue.js +1 -1
- 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 +3 -3
- 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 +25 -25
- 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 +3 -3
- package/dist/martyrs/src/modules/events/components/pages/EditEventTickets.vue.js +16 -16
- package/dist/martyrs/src/modules/events/components/pages/Event.vue.cjs +9 -2
- package/dist/martyrs/src/modules/events/components/pages/Event.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/events/components/pages/Event.vue.js +9 -2
- package/dist/martyrs/src/modules/events/components/pages/Event.vue.js.map +1 -1
- 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 +4 -3
- package/dist/martyrs/src/modules/gallery/components/sections/BackofficeGallery.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/gallery/components/sections/BackofficeGallery.vue.js +4 -3
- package/dist/martyrs/src/modules/gallery/components/sections/BackofficeGallery.vue.js.map +1 -1
- package/dist/martyrs/src/modules/globals/views/classes/globals.i18n.cjs +1 -1
- package/dist/martyrs/src/modules/globals/views/classes/globals.i18n.js +1 -1
- package/dist/martyrs/src/modules/globals/views/classes/globals.store.cjs +24 -58
- package/dist/martyrs/src/modules/globals/views/classes/globals.store.cjs.map +1 -1
- package/dist/martyrs/src/modules/globals/views/classes/globals.store.js +24 -58
- package/dist/martyrs/src/modules/globals/views/classes/globals.store.js.map +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/BlockSearch.vue.cjs +1 -1
- package/dist/martyrs/src/modules/globals/views/components/blocks/BlockSearch.vue.js +2 -2
- 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 +2 -1
- package/dist/martyrs/src/modules/globals/views/components/sections/Filters.vue2.cjs.map +1 -1
- package/dist/martyrs/src/modules/globals/views/components/sections/Filters.vue2.js +2 -1
- package/dist/martyrs/src/modules/globals/views/components/sections/Filters.vue2.js.map +1 -1
- package/dist/martyrs/src/modules/globals/views/components/sections/filters/FilterOptions.vue.cjs +1 -1
- package/dist/martyrs/src/modules/globals/views/components/sections/filters/FilterOptions.vue.js +2 -2
- package/dist/martyrs/src/modules/globals/views/components/sections/filters/FilterPrice.vue.cjs +1 -1
- package/dist/martyrs/src/modules/globals/views/components/sections/filters/FilterPrice.vue.js +3 -3
- package/dist/martyrs/src/modules/globals/views/store/globals.cjs +6 -0
- package/dist/martyrs/src/modules/globals/views/store/globals.cjs.map +1 -1
- package/dist/martyrs/src/modules/globals/views/store/globals.js +6 -0
- package/dist/martyrs/src/modules/globals/views/store/globals.js.map +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/globals/views/utils/query-serializer.cjs +100 -0
- package/dist/martyrs/src/modules/globals/views/utils/query-serializer.cjs.map +1 -0
- package/dist/martyrs/src/modules/globals/views/utils/query-serializer.js +100 -0
- package/dist/martyrs/src/modules/globals/views/utils/query-serializer.js.map +1 -0
- package/dist/martyrs/src/modules/icons/components/IconSearchPopup.vue.cjs +224 -0
- package/dist/martyrs/src/modules/icons/components/IconSearchPopup.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/icons/components/IconSearchPopup.vue.js +224 -0
- package/dist/martyrs/src/modules/icons/components/IconSearchPopup.vue.js.map +1 -0
- package/dist/martyrs/src/modules/icons/entities/IconAddress.vue.cjs +40 -0
- package/dist/martyrs/src/modules/icons/entities/IconAddress.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/icons/entities/IconAddress.vue.js +40 -0
- package/dist/martyrs/src/modules/icons/entities/IconAddress.vue.js.map +1 -0
- package/dist/martyrs/src/modules/icons/entities/IconDate.vue.cjs +6 -6
- package/dist/martyrs/src/modules/icons/entities/IconDate.vue.js +6 -6
- package/dist/martyrs/src/modules/icons/entities/IconEmail.vue.cjs +32 -0
- package/dist/martyrs/src/modules/icons/entities/IconEmail.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/icons/entities/IconEmail.vue.js +32 -0
- package/dist/martyrs/src/modules/icons/entities/IconEmail.vue.js.map +1 -0
- package/dist/martyrs/src/modules/icons/entities/IconMusic.vue.cjs +10 -12
- package/dist/martyrs/src/modules/icons/entities/IconMusic.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/icons/entities/IconMusic.vue.js +11 -13
- package/dist/martyrs/src/modules/icons/entities/IconMusic.vue.js.map +1 -1
- package/dist/martyrs/src/modules/icons/entities/IconPhone.vue.cjs +32 -0
- package/dist/martyrs/src/modules/icons/entities/IconPhone.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/icons/entities/IconPhone.vue.js +32 -0
- package/dist/martyrs/src/modules/icons/entities/IconPhone.vue.js.map +1 -0
- package/dist/martyrs/src/modules/icons/icons.client.cjs +48 -4
- package/dist/martyrs/src/modules/icons/icons.client.cjs.map +1 -1
- package/dist/martyrs/src/modules/icons/icons.client.js +172 -128
- package/dist/martyrs/src/modules/icons/icons.client.js.map +1 -1
- package/dist/martyrs/src/modules/icons/navigation/IconCross.vue.cjs +5 -7
- package/dist/martyrs/src/modules/icons/navigation/IconCross.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/icons/navigation/IconCross.vue.js +5 -7
- package/dist/martyrs/src/modules/icons/navigation/IconCross.vue.js.map +1 -1
- package/dist/martyrs/src/modules/icons/navigation/IconPause.vue.cjs +6 -11
- package/dist/martyrs/src/modules/icons/navigation/IconPause.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/icons/navigation/IconPause.vue.js +6 -11
- package/dist/martyrs/src/modules/icons/navigation/IconPause.vue.js.map +1 -1
- package/dist/martyrs/src/modules/icons/navigation/IconRefresh.vue.cjs +6 -11
- package/dist/martyrs/src/modules/icons/navigation/IconRefresh.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/icons/navigation/IconRefresh.vue.js +6 -11
- package/dist/martyrs/src/modules/icons/navigation/IconRefresh.vue.js.map +1 -1
- package/dist/martyrs/src/modules/icons/pages/IconsPage.vue.cjs +62 -6
- package/dist/martyrs/src/modules/icons/pages/IconsPage.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/icons/pages/IconsPage.vue.js +189 -133
- package/dist/martyrs/src/modules/icons/pages/IconsPage.vue.js.map +1 -1
- package/dist/martyrs/src/modules/icons/socials/dribbble.vue.cjs +21 -12
- package/dist/martyrs/src/modules/icons/socials/dribbble.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/icons/socials/dribbble.vue.js +21 -12
- package/dist/martyrs/src/modules/icons/socials/dribbble.vue.js.map +1 -1
- package/dist/martyrs/src/modules/icons/socials/facebook.vue.cjs +21 -12
- package/dist/martyrs/src/modules/icons/socials/facebook.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/icons/socials/facebook.vue.js +21 -12
- package/dist/martyrs/src/modules/icons/socials/facebook.vue.js.map +1 -1
- package/dist/martyrs/src/modules/icons/socials/instagram.vue.cjs +25 -17
- package/dist/martyrs/src/modules/icons/socials/instagram.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/icons/socials/instagram.vue.js +25 -17
- package/dist/martyrs/src/modules/icons/socials/instagram.vue.js.map +1 -1
- package/dist/martyrs/src/modules/icons/socials/line.vue.cjs +23 -14
- package/dist/martyrs/src/modules/icons/socials/line.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/icons/socials/line.vue.js +23 -14
- package/dist/martyrs/src/modules/icons/socials/line.vue.js.map +1 -1
- package/dist/martyrs/src/modules/icons/socials/linkedin.vue.cjs +26 -17
- package/dist/martyrs/src/modules/icons/socials/linkedin.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/icons/socials/linkedin.vue.js +26 -17
- package/dist/martyrs/src/modules/icons/socials/linkedin.vue.js.map +1 -1
- package/dist/martyrs/src/modules/icons/socials/reddit.vue.cjs +21 -12
- package/dist/martyrs/src/modules/icons/socials/reddit.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/icons/socials/reddit.vue.js +21 -12
- package/dist/martyrs/src/modules/icons/socials/reddit.vue.js.map +1 -1
- package/dist/martyrs/src/modules/icons/socials/telegram.vue.cjs +29 -20
- package/dist/martyrs/src/modules/icons/socials/telegram.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/icons/socials/telegram.vue.js +29 -20
- package/dist/martyrs/src/modules/icons/socials/telegram.vue.js.map +1 -1
- package/dist/martyrs/src/modules/icons/socials/twitter.vue.cjs +21 -12
- package/dist/martyrs/src/modules/icons/socials/twitter.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/icons/socials/twitter.vue.js +21 -12
- package/dist/martyrs/src/modules/icons/socials/twitter.vue.js.map +1 -1
- package/dist/martyrs/src/modules/icons/socials/vk.vue.cjs +21 -12
- package/dist/martyrs/src/modules/icons/socials/vk.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/icons/socials/vk.vue.js +21 -12
- package/dist/martyrs/src/modules/icons/socials/vk.vue.js.map +1 -1
- package/dist/martyrs/src/modules/icons/socials/whatsapp.vue.cjs +32 -0
- package/dist/martyrs/src/modules/icons/socials/whatsapp.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/icons/socials/whatsapp.vue.js +32 -0
- package/dist/martyrs/src/modules/icons/socials/whatsapp.vue.js.map +1 -0
- package/dist/martyrs/src/modules/icons/socials/youtube.vue.cjs +21 -12
- package/dist/martyrs/src/modules/icons/socials/youtube.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/icons/socials/youtube.vue.js +21 -12
- package/dist/martyrs/src/modules/icons/socials/youtube.vue.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/cards/TrackListCard.vue.cjs +162 -0
- package/dist/martyrs/src/modules/music/components/cards/TrackListCard.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/cards/TrackListCard.vue.js +162 -0
- package/dist/martyrs/src/modules/music/components/cards/TrackListCard.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/forms/AlbumForm.vue.cjs +437 -0
- package/dist/martyrs/src/modules/music/components/forms/AlbumForm.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/forms/AlbumForm.vue.js +437 -0
- package/dist/martyrs/src/modules/music/components/forms/AlbumForm.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/forms/ArtistForm.vue.cjs +416 -0
- package/dist/martyrs/src/modules/music/components/forms/ArtistForm.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/forms/ArtistForm.vue.js +416 -0
- package/dist/martyrs/src/modules/music/components/forms/ArtistForm.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/TrackForm.vue.cjs +554 -0
- package/dist/martyrs/src/modules/music/components/forms/TrackForm.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/forms/TrackForm.vue.js +554 -0
- package/dist/martyrs/src/modules/music/components/forms/TrackForm.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/layouts/MusicLayout.vue.cjs +104 -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 +104 -0
- package/dist/martyrs/src/modules/music/components/layouts/MusicLayout.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/Album.vue.cjs +314 -0
- package/dist/martyrs/src/modules/music/components/pages/Album.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/Album.vue.js +314 -0
- package/dist/martyrs/src/modules/music/components/pages/Album.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/AlbumCreate.vue.cjs +14 -0
- package/dist/martyrs/src/modules/music/components/pages/AlbumCreate.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/AlbumCreate.vue.js +14 -0
- package/dist/martyrs/src/modules/music/components/pages/AlbumCreate.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/AlbumEdit.vue.cjs +23 -0
- package/dist/martyrs/src/modules/music/components/pages/AlbumEdit.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/AlbumEdit.vue.js +23 -0
- package/dist/martyrs/src/modules/music/components/pages/AlbumEdit.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/Artist.vue.cjs +467 -0
- package/dist/martyrs/src/modules/music/components/pages/Artist.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/Artist.vue.js +467 -0
- package/dist/martyrs/src/modules/music/components/pages/Artist.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/ArtistCreate.vue.cjs +14 -0
- package/dist/martyrs/src/modules/music/components/pages/ArtistCreate.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/ArtistCreate.vue.js +14 -0
- package/dist/martyrs/src/modules/music/components/pages/ArtistCreate.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/ArtistEdit.vue.cjs +23 -0
- package/dist/martyrs/src/modules/music/components/pages/ArtistEdit.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/ArtistEdit.vue.js +23 -0
- package/dist/martyrs/src/modules/music/components/pages/ArtistEdit.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/MusicHome.vue.cjs +256 -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 +256 -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 +248 -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 +248 -0
- package/dist/martyrs/src/modules/music/components/pages/MusicLibrary.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/Playlist.vue.cjs +580 -0
- package/dist/martyrs/src/modules/music/components/pages/Playlist.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/Playlist.vue.js +580 -0
- package/dist/martyrs/src/modules/music/components/pages/Playlist.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/PlaylistCreate.vue.cjs +14 -0
- package/dist/martyrs/src/modules/music/components/pages/PlaylistCreate.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/PlaylistCreate.vue.js +14 -0
- package/dist/martyrs/src/modules/music/components/pages/PlaylistCreate.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/PlaylistEdit.vue.cjs +23 -0
- package/dist/martyrs/src/modules/music/components/pages/PlaylistEdit.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/PlaylistEdit.vue.js +23 -0
- package/dist/martyrs/src/modules/music/components/pages/PlaylistEdit.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/SearchResults.vue.cjs +473 -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 +473 -0
- package/dist/martyrs/src/modules/music/components/pages/SearchResults.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/Track.vue.cjs +111 -0
- package/dist/martyrs/src/modules/music/components/pages/Track.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/Track.vue.js +111 -0
- package/dist/martyrs/src/modules/music/components/pages/Track.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/TrackCreate.vue.cjs +28 -0
- package/dist/martyrs/src/modules/music/components/pages/TrackCreate.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/TrackCreate.vue.js +28 -0
- package/dist/martyrs/src/modules/music/components/pages/TrackCreate.vue.js.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/TrackEdit.vue.cjs +23 -0
- package/dist/martyrs/src/modules/music/components/pages/TrackEdit.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/components/pages/TrackEdit.vue.js +23 -0
- package/dist/martyrs/src/modules/music/components/pages/TrackEdit.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/albums.cjs +34 -0
- package/dist/martyrs/src/modules/music/router/albums.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/router/albums.js +34 -0
- package/dist/martyrs/src/modules/music/router/albums.js.map +1 -0
- package/dist/martyrs/src/modules/music/router/artists.cjs +34 -0
- package/dist/martyrs/src/modules/music/router/artists.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/router/artists.js +34 -0
- package/dist/martyrs/src/modules/music/router/artists.js.map +1 -0
- package/dist/martyrs/src/modules/music/router/music.cjs +47 -0
- package/dist/martyrs/src/modules/music/router/music.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/router/music.js +47 -0
- package/dist/martyrs/src/modules/music/router/music.js.map +1 -0
- package/dist/martyrs/src/modules/music/router/playlists.cjs +34 -0
- package/dist/martyrs/src/modules/music/router/playlists.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/router/playlists.js +34 -0
- package/dist/martyrs/src/modules/music/router/playlists.js.map +1 -0
- package/dist/martyrs/src/modules/music/router/tracks.cjs +34 -0
- package/dist/martyrs/src/modules/music/router/tracks.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/router/tracks.js +34 -0
- package/dist/martyrs/src/modules/music/router/tracks.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 +160 -0
- package/dist/martyrs/src/modules/music/store/artists.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/store/artists.js +160 -0
- package/dist/martyrs/src/modules/music/store/artists.js.map +1 -0
- package/dist/martyrs/src/modules/music/store/genres.cjs +123 -0
- package/dist/martyrs/src/modules/music/store/genres.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/store/genres.js +123 -0
- package/dist/martyrs/src/modules/music/store/genres.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 +182 -0
- package/dist/martyrs/src/modules/music/store/playlists.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/store/playlists.js +182 -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 +184 -0
- package/dist/martyrs/src/modules/music/store/tracks.cjs.map +1 -0
- package/dist/martyrs/src/modules/music/store/tracks.js +184 -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 +3 -2
- package/dist/martyrs/src/modules/orders/components/pages/OrderCreateBackoffice.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/orders/components/pages/OrderCreateBackoffice.vue.js +3 -2
- package/dist/martyrs/src/modules/orders/components/pages/OrderCreateBackoffice.vue.js.map +1 -1
- package/dist/martyrs/src/modules/orders/components/sections/FormAddCustomer.vue.cjs +2 -1
- package/dist/martyrs/src/modules/orders/components/sections/FormAddCustomer.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/orders/components/sections/FormAddCustomer.vue.js +2 -1
- package/dist/martyrs/src/modules/orders/components/sections/FormAddCustomer.vue.js.map +1 -1
- package/dist/martyrs/src/modules/orders/components/sections/FormCustomerDetails.vue.cjs +1 -1
- package/dist/martyrs/src/modules/orders/components/sections/FormCustomerDetails.vue.js +5 -5
- package/dist/martyrs/src/modules/orders/components/sections/FormDelivery.vue.cjs +2 -2
- package/dist/martyrs/src/modules/orders/components/sections/FormDelivery.vue.js +3 -3
- package/dist/martyrs/src/modules/organizations/components/blocks/CardOrganization.vue.cjs +1 -1
- package/dist/martyrs/src/modules/organizations/components/blocks/CardOrganization.vue.js +1 -1
- package/dist/martyrs/src/modules/organizations/components/blocks/Socials.vue.js +16 -16
- 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 +3 -3
- package/dist/martyrs/src/modules/organizations/components/pages/DepartmentEdit.vue.js +16 -16
- 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 +3 -3
- package/dist/martyrs/src/modules/organizations/components/pages/OrganizationEdit.vue.js +17 -17
- package/dist/martyrs/src/modules/organizations/components/sections/DetailsTabSection.vue.cjs +1 -1
- package/dist/martyrs/src/modules/organizations/components/sections/DetailsTabSection.vue.js +1 -1
- package/dist/martyrs/src/modules/organizations/components/sections/Documents.vue.cjs +3 -3
- package/dist/martyrs/src/modules/organizations/components/sections/Documents.vue.js +4 -4
- package/dist/martyrs/src/modules/organizations/components/sections/MembersAdd.vue.cjs +2 -2
- package/dist/martyrs/src/modules/organizations/components/sections/MembersAdd.vue.js +8 -8
- package/dist/martyrs/src/modules/organizations/components/sections/Organizations.vue.cjs +2 -1
- package/dist/martyrs/src/modules/organizations/components/sections/Organizations.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/organizations/components/sections/Organizations.vue.js +2 -1
- package/dist/martyrs/src/modules/organizations/components/sections/Organizations.vue.js.map +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 +2 -1
- package/dist/martyrs/src/modules/pages/views/components/blocks/CardPage.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/pages/views/components/blocks/CardPage.vue.js +2 -1
- package/dist/martyrs/src/modules/pages/views/components/blocks/CardPage.vue.js.map +1 -1
- package/dist/martyrs/src/modules/pages/views/components/pages/PageEdit.vue.cjs +2 -1
- package/dist/martyrs/src/modules/pages/views/components/pages/PageEdit.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/pages/views/components/pages/PageEdit.vue.js +2 -1
- package/dist/martyrs/src/modules/pages/views/components/pages/PageEdit.vue.js.map +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/ProductDiscounts.vue.cjs +1 -1
- package/dist/martyrs/src/modules/products/components/blocks/ProductDiscounts.vue.js +1 -1
- 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/forms/ReorderSettingsForm.vue.cjs +1 -1
- package/dist/martyrs/src/modules/products/components/forms/ReorderSettingsForm.vue.js +8 -8
- package/dist/martyrs/src/modules/products/components/forms/StockAuditForm.vue.cjs +1 -1
- package/dist/martyrs/src/modules/products/components/forms/StockAuditForm.vue.js +12 -12
- 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 +3 -3
- package/dist/martyrs/src/modules/products/components/pages/CategoryEdit.vue.js +13 -13
- package/dist/martyrs/src/modules/products/components/pages/LeftoverEdit.vue.cjs +3 -3
- package/dist/martyrs/src/modules/products/components/pages/LeftoverEdit.vue.js +11 -11
- 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 +2 -2
- package/dist/martyrs/src/modules/products/components/pages/ProductEdit.vue.js +18 -18
- package/dist/martyrs/src/modules/products/components/sections/EditAttributes.vue.cjs +3 -3
- package/dist/martyrs/src/modules/products/components/sections/EditAttributes.vue.js +7 -7
- package/dist/martyrs/src/modules/products/components/sections/EditDiscounts.vue.cjs +3 -3
- package/dist/martyrs/src/modules/products/components/sections/EditDiscounts.vue.js +13 -13
- 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 +3 -3
- package/dist/martyrs/src/modules/products/components/sections/EditVariants.vue.js +17 -17
- 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 +2 -2
- package/dist/martyrs/src/modules/rents/views/components/pages/RentsEdit.vue.js +5 -5
- 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/blocks/CardSpot.vue.cjs +1 -1
- package/dist/martyrs/src/modules/spots/components/blocks/CardSpot.vue.js +1 -1
- package/dist/martyrs/src/modules/spots/components/blocks/SpotMemberModify.vue.cjs +1 -0
- package/dist/martyrs/src/modules/spots/components/blocks/SpotMemberModify.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/spots/components/blocks/SpotMemberModify.vue.js +1 -0
- package/dist/martyrs/src/modules/spots/components/blocks/SpotMemberModify.vue.js.map +1 -1
- package/dist/martyrs/src/modules/spots/components/layouts/Spots.vue.cjs +1 -0
- package/dist/martyrs/src/modules/spots/components/layouts/Spots.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/spots/components/layouts/Spots.vue.js +1 -0
- package/dist/martyrs/src/modules/spots/components/layouts/Spots.vue.js.map +1 -1
- 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 +3 -3
- package/dist/martyrs/src/modules/spots/components/pages/SpotEdit.vue.js +14 -14
- package/dist/martyrs/src/modules/spots/components/sections/WorktimeEdit.vue.cjs +3 -3
- package/dist/martyrs/src/modules/spots/components/sections/WorktimeEdit.vue.js +9 -9
- package/dist/martyrs/src/modules/wallet/views/components/blocks/CardDeposit.vue.cjs +1 -1
- package/dist/martyrs/src/modules/wallet/views/components/blocks/CardDeposit.vue.js +2 -2
- package/dist/martyrs/src/modules/wallet/views/components/blocks/CryptoDeposit.vue.cjs +1 -1
- package/dist/martyrs/src/modules/wallet/views/components/blocks/CryptoDeposit.vue.js +2 -2
- package/dist/martyrs/src/modules/wallet/views/components/pages/Wallet.vue.cjs +3 -3
- package/dist/martyrs/src/modules/wallet/views/components/pages/Wallet.vue.js +3 -3
- 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 +2021 -0
- package/dist/music.server.js +2021 -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 +1 -1
- package/dist/orders.server.js +1 -1
- package/dist/organizations.server.cjs +1 -1
- package/dist/organizations.server.js +1 -1
- package/dist/products.server.cjs +3 -1093
- package/dist/products.server.js +2 -1092
- package/dist/rents.server.cjs +1 -1
- package/dist/rents.server.js +1 -1
- package/dist/socials.schema-BOZV82Mp.js +25 -0
- package/dist/socials.schema-CtpSF9dE.cjs +24 -0
- package/dist/style.css +230 -46
- package/dist/wallet.server.cjs +1 -1
- package/dist/wallet.server.js +1 -1
- package/package.json +1 -1
- package/src/.martyrs/filemap.json +2 -2
- package/src/components/Feed/Feed.vue +1 -1
- package/src/components/Field/Field.vue +13 -8
- package/src/components/FieldBig/FieldBig.vue +3 -5
- package/src/components/FieldPhone/FieldPhone.vue +1 -1
- package/src/components/Media/Media.vue +1 -1
- package/src/components/Select/Select.vue +1 -1
- package/src/components/Status/Snack.vue +83 -0
- package/src/components/index.js +2 -0
- package/src/main.js +6 -0
- package/src/modules/auth/controllers/middlewares/authJwt.js +59 -6
- package/src/modules/events/components/pages/EditEvent.vue +1 -1
- package/src/modules/globals/views/classes/globals.store.js +31 -66
- package/src/modules/globals/views/components/blocks/PopupDateSelector.vue +1 -1
- package/src/modules/globals/views/components/partials/FooterAlt.vue +363 -0
- package/src/modules/globals/views/store/globals.js +42 -0
- package/src/modules/globals/views/utils/axios-instance.js +15 -1
- package/src/modules/globals/views/utils/query-serializer.js +182 -0
- package/src/modules/icons/components/IconSearchPopup.vue +254 -0
- package/src/modules/icons/entities/IconAddress.vue +17 -0
- package/src/modules/icons/entities/IconDate.vue +3 -3
- package/src/modules/icons/entities/IconEmail.vue +14 -0
- package/src/modules/icons/entities/IconMusic.vue +3 -3
- package/src/modules/icons/entities/IconPhone.vue +14 -0
- package/src/modules/icons/icons.client.js +85 -31
- package/src/modules/icons/icons.server.js +292 -0
- package/src/modules/icons/navigation/IconCross.vue +4 -16
- package/src/modules/icons/navigation/IconPause.vue +9 -24
- package/src/modules/icons/navigation/IconRefresh.vue +9 -24
- package/src/modules/icons/pages/IconsPage.vue +78 -2
- package/src/modules/icons/routes/icons.routes.js +81 -0
- package/src/modules/icons/socials/dribbble.vue +11 -2
- package/src/modules/icons/socials/facebook.vue +11 -2
- package/src/modules/icons/socials/instagram.vue +11 -4
- package/src/modules/icons/socials/line.vue +11 -2
- package/src/modules/icons/socials/linkedin.vue +11 -2
- package/src/modules/icons/socials/reddit.vue +10 -1
- package/src/modules/icons/socials/telegram.vue +11 -2
- package/src/modules/icons/socials/twitter.vue +11 -2
- package/src/modules/icons/socials/vk.vue +11 -2
- package/src/modules/icons/socials/whatsapp.vue +12 -0
- package/src/modules/icons/socials/youtube.vue +11 -2
- package/src/modules/music/.claude/settings.local.json +8 -0
- package/src/modules/music/CLAUDE.md +312 -0
- package/src/modules/music/components/SidebarMusic.vue +8 -8
- package/src/modules/music/components/cards/AlbumCard.vue +2 -2
- package/src/modules/music/components/cards/ArtistCard.vue +2 -2
- package/src/modules/music/components/cards/PlaylistCard.vue +2 -2
- package/src/modules/music/components/cards/TrackCard.vue +1 -1
- package/src/modules/music/components/cards/TrackListCard.vue +135 -0
- package/src/modules/music/components/forms/AlbumForm.vue +463 -0
- package/src/modules/music/components/{pages → forms}/ArtistForm.vue +127 -96
- package/src/modules/music/components/forms/PlaylistForm.vue +10 -10
- package/src/modules/music/components/forms/SearchForm.vue +1 -1
- package/src/modules/music/components/forms/TrackForm.vue +577 -0
- package/src/modules/music/components/layouts/MusicLayout.vue +35 -41
- package/src/modules/music/components/pages/{AlbumDetail.vue → Album.vue} +42 -20
- package/src/modules/music/components/pages/AlbumCreate.vue +7 -0
- package/src/modules/music/components/pages/AlbumEdit.vue +14 -0
- package/src/modules/music/components/pages/{ArtistDetail.vue → Artist.vue} +9 -9
- package/src/modules/music/components/pages/ArtistCreate.vue +7 -0
- package/src/modules/music/components/pages/ArtistEdit.vue +14 -0
- package/src/modules/music/components/pages/MusicHome.vue +86 -67
- package/src/modules/music/components/pages/MusicLibrary.vue +136 -105
- package/src/modules/music/components/pages/{PlaylistDetail.vue → Playlist.vue} +56 -34
- package/src/modules/music/components/pages/PlaylistCreate.vue +7 -0
- package/src/modules/music/components/pages/PlaylistEdit.vue +14 -0
- package/src/modules/music/components/pages/SearchResults.vue +49 -27
- package/src/modules/music/components/pages/{TrackDetail.vue → Track.vue} +36 -14
- package/src/modules/music/components/pages/TrackCreate.vue +23 -0
- package/src/modules/music/components/pages/TrackEdit.vue +14 -0
- package/src/modules/music/components/player/MusicPlayer.vue +2 -2
- package/src/modules/music/middlewares/albums.verifier.js +234 -0
- package/src/modules/music/middlewares/artists.verifier.js +213 -0
- package/src/modules/music/middlewares/genres.verifier.js +148 -0
- package/src/modules/music/middlewares/playlists.verifier.js +219 -0
- package/src/modules/music/middlewares/tracks.verifier.js +263 -0
- package/src/modules/music/music.client.js +31 -33
- package/src/modules/music/music.server.js +33 -26
- package/src/modules/music/router/albums.js +31 -0
- package/src/modules/music/router/artists.js +31 -0
- package/src/modules/music/router/music.js +14 -65
- package/src/modules/music/router/playlists.js +31 -0
- package/src/modules/music/router/tracks.js +31 -0
- package/src/modules/music/routes/albums.routes.js +126 -0
- package/src/modules/music/routes/artists.routes.js +171 -0
- package/src/modules/music/routes/genres.routes.js +118 -0
- package/src/modules/music/routes/playlists.routes.js +239 -0
- package/src/modules/music/routes/tracks.routes.js +149 -0
- package/src/modules/music/store/artists.js +17 -7
- package/src/modules/music/store/genres.js +150 -0
- package/src/modules/music/store/playlists.js +19 -6
- package/src/modules/music/store/tracks.js +9 -2
- package/src/modules/products/components/pages/Product.vue +1 -1
- package/dist/Media-ByPHBvAU.cjs +0 -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/Chips/Chips.vue2.cjs.map +0 -1
- package/dist/martyrs/src/components/Chips/Chips.vue2.js.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/Field/Field.vue.cjs.map +0 -1
- package/dist/martyrs/src/components/Field/Field.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/modules/music/components/forms/UploadForm.vue +0 -313
- package/src/modules/music/components/lists/AlbumList.vue +0 -25
- package/src/modules/music/components/lists/ArtistList.vue +0 -280
- package/src/modules/music/components/lists/PlaylistList.vue +0 -25
- package/src/modules/music/components/lists/TrackList.vue +0 -175
- package/src/modules/music/components/pages/ArtistManager.vue +0 -277
- package/src/modules/music/components/pages/MusicUpload.vue +0 -44
- package/src/modules/music/controllers/album.controller.js +0 -82
- package/src/modules/music/controllers/artist.controller.js +0 -99
- package/src/modules/music/controllers/genre.controller.js +0 -63
- package/src/modules/music/controllers/music.controller.js +0 -145
- package/src/modules/music/controllers/playlist.controller.js +0 -146
- package/src/modules/music/routes/album.routes.js +0 -28
- package/src/modules/music/routes/artist.routes.js +0 -30
- package/src/modules/music/routes/genre.routes.js +0 -28
- package/src/modules/music/routes/music.routes.js +0 -106
- package/src/modules/music/routes/playlist.routes.js +0 -47
- /package/src/components/{DatePicker → Calendar}/Calendar.vue +0 -0
|
@@ -0,0 +1,182 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
+
const globals_store = require("../../globals/views/classes/globals.store.cjs");
|
|
4
|
+
const vue = require("vue");
|
|
5
|
+
const playlistStore = new globals_store.default(`${process.env.API_URL}/api/playlists`);
|
|
6
|
+
const state = vue.reactive({
|
|
7
|
+
playlists: [],
|
|
8
|
+
featuredPlaylists: [],
|
|
9
|
+
userPlaylists: [],
|
|
10
|
+
currentPlaylist: null,
|
|
11
|
+
currentPlaylistTracks: [],
|
|
12
|
+
isLoading: false,
|
|
13
|
+
loadingFeatured: false
|
|
14
|
+
});
|
|
15
|
+
const actions = {
|
|
16
|
+
async fetchPlaylists(options = {}) {
|
|
17
|
+
state.isLoading = true;
|
|
18
|
+
try {
|
|
19
|
+
const playlists = await playlistStore.read(options);
|
|
20
|
+
state.playlists = playlists;
|
|
21
|
+
return playlists;
|
|
22
|
+
} catch (error) {
|
|
23
|
+
console.error("Error fetching playlists:", error);
|
|
24
|
+
return [];
|
|
25
|
+
} finally {
|
|
26
|
+
state.isLoading = false;
|
|
27
|
+
}
|
|
28
|
+
},
|
|
29
|
+
async fetchFeaturedPlaylists(options = {}) {
|
|
30
|
+
state.loadingFeatured = true;
|
|
31
|
+
try {
|
|
32
|
+
const queryOptions = {
|
|
33
|
+
limit: options.limit || 10,
|
|
34
|
+
isPublic: true
|
|
35
|
+
};
|
|
36
|
+
if (options.skip) queryOptions.skip = options.skip;
|
|
37
|
+
if (options.search) queryOptions.search = options.search;
|
|
38
|
+
if (options.sortParam) queryOptions.sortParam = options.sortParam;
|
|
39
|
+
if (options.sortOrder) queryOptions.sortOrder = options.sortOrder;
|
|
40
|
+
if (options.featured) {
|
|
41
|
+
queryOptions.status = "featured";
|
|
42
|
+
queryOptions.sortParam = queryOptions.sortParam || "followers";
|
|
43
|
+
queryOptions.sortOrder = queryOptions.sortOrder || "desc";
|
|
44
|
+
}
|
|
45
|
+
const playlists = await playlistStore.read(queryOptions);
|
|
46
|
+
state.featuredPlaylists = playlists;
|
|
47
|
+
return playlists;
|
|
48
|
+
} catch (error) {
|
|
49
|
+
console.error("Error fetching featured playlists:", error);
|
|
50
|
+
return [];
|
|
51
|
+
} finally {
|
|
52
|
+
state.loadingFeatured = false;
|
|
53
|
+
}
|
|
54
|
+
},
|
|
55
|
+
async fetchPlaylistByUrl(url) {
|
|
56
|
+
var _a;
|
|
57
|
+
try {
|
|
58
|
+
const response = await fetch(`${process.env.API_URL}/api/playlists/url/${url}`);
|
|
59
|
+
const playlist = await response.json();
|
|
60
|
+
state.currentPlaylist = playlist;
|
|
61
|
+
state.currentPlaylistTracks = ((_a = playlist.tracks) == null ? void 0 : _a.map((item) => item.track)) || [];
|
|
62
|
+
return playlist;
|
|
63
|
+
} catch (error) {
|
|
64
|
+
console.error("Error fetching playlist by URL:", error);
|
|
65
|
+
return null;
|
|
66
|
+
}
|
|
67
|
+
},
|
|
68
|
+
async createPlaylist(playlistData) {
|
|
69
|
+
try {
|
|
70
|
+
const createdPlaylist = await playlistStore.create(playlistData);
|
|
71
|
+
state.playlists.unshift(createdPlaylist);
|
|
72
|
+
state.userPlaylists.unshift(createdPlaylist);
|
|
73
|
+
return createdPlaylist;
|
|
74
|
+
} catch (error) {
|
|
75
|
+
console.error("Error creating playlist:", error);
|
|
76
|
+
throw error;
|
|
77
|
+
}
|
|
78
|
+
},
|
|
79
|
+
async updatePlaylist(playlistData) {
|
|
80
|
+
try {
|
|
81
|
+
const updatedPlaylist = await playlistStore.update(playlistData);
|
|
82
|
+
const index = state.playlists.findIndex((p) => p._id === updatedPlaylist._id);
|
|
83
|
+
if (index !== -1) {
|
|
84
|
+
state.playlists[index] = updatedPlaylist;
|
|
85
|
+
}
|
|
86
|
+
const userIndex = state.userPlaylists.findIndex((p) => p._id === updatedPlaylist._id);
|
|
87
|
+
if (userIndex !== -1) {
|
|
88
|
+
state.userPlaylists[userIndex] = updatedPlaylist;
|
|
89
|
+
}
|
|
90
|
+
if (state.currentPlaylist && state.currentPlaylist._id === updatedPlaylist._id) {
|
|
91
|
+
state.currentPlaylist = updatedPlaylist;
|
|
92
|
+
}
|
|
93
|
+
return updatedPlaylist;
|
|
94
|
+
} catch (error) {
|
|
95
|
+
console.error("Error updating playlist:", error);
|
|
96
|
+
throw error;
|
|
97
|
+
}
|
|
98
|
+
},
|
|
99
|
+
async deletePlaylist(playlistId) {
|
|
100
|
+
try {
|
|
101
|
+
await playlistStore.delete({ _id: playlistId });
|
|
102
|
+
state.playlists = state.playlists.filter((p) => p._id !== playlistId);
|
|
103
|
+
state.userPlaylists = state.userPlaylists.filter((p) => p._id !== playlistId);
|
|
104
|
+
if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {
|
|
105
|
+
state.currentPlaylist = null;
|
|
106
|
+
state.currentPlaylistTracks = [];
|
|
107
|
+
}
|
|
108
|
+
return true;
|
|
109
|
+
} catch (error) {
|
|
110
|
+
console.error("Error deleting playlist:", error);
|
|
111
|
+
throw error;
|
|
112
|
+
}
|
|
113
|
+
},
|
|
114
|
+
async fetchUserPlaylists(userId) {
|
|
115
|
+
try {
|
|
116
|
+
const response = await fetch(`${process.env.API_URL}/api/playlists/user/${userId || ""}`);
|
|
117
|
+
const playlists = await response.json();
|
|
118
|
+
state.userPlaylists = playlists;
|
|
119
|
+
return playlists;
|
|
120
|
+
} catch (error) {
|
|
121
|
+
console.error("Error fetching user playlists:", error);
|
|
122
|
+
return [];
|
|
123
|
+
}
|
|
124
|
+
},
|
|
125
|
+
async addTrackToPlaylist(playlistId, trackId) {
|
|
126
|
+
var _a;
|
|
127
|
+
try {
|
|
128
|
+
const response = await fetch(`${process.env.API_URL}/api/playlists/${playlistId}/tracks/${trackId}`, {
|
|
129
|
+
method: "POST",
|
|
130
|
+
headers: {
|
|
131
|
+
"Content-Type": "application/json"
|
|
132
|
+
}
|
|
133
|
+
});
|
|
134
|
+
const updatedPlaylist = await response.json();
|
|
135
|
+
if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {
|
|
136
|
+
state.currentPlaylist = updatedPlaylist;
|
|
137
|
+
const track = (_a = updatedPlaylist.tracks.find((item) => item.track._id === trackId)) == null ? void 0 : _a.track;
|
|
138
|
+
if (track && !state.currentPlaylistTracks.some((t) => t._id === trackId)) {
|
|
139
|
+
state.currentPlaylistTracks.push(track);
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
return updatedPlaylist;
|
|
143
|
+
} catch (error) {
|
|
144
|
+
console.error("Error adding track to playlist:", error);
|
|
145
|
+
throw error;
|
|
146
|
+
}
|
|
147
|
+
},
|
|
148
|
+
async removeTrackFromPlaylist(playlistId, trackId) {
|
|
149
|
+
try {
|
|
150
|
+
const response = await fetch(`${process.env.API_URL}/api/playlists/${playlistId}/tracks/${trackId}`, {
|
|
151
|
+
method: "DELETE"
|
|
152
|
+
});
|
|
153
|
+
const updatedPlaylist = await response.json();
|
|
154
|
+
if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {
|
|
155
|
+
state.currentPlaylist = updatedPlaylist;
|
|
156
|
+
state.currentPlaylistTracks = state.currentPlaylistTracks.filter((track) => track._id !== trackId);
|
|
157
|
+
}
|
|
158
|
+
return updatedPlaylist;
|
|
159
|
+
} catch (error) {
|
|
160
|
+
console.error("Error removing track from playlist:", error);
|
|
161
|
+
throw error;
|
|
162
|
+
}
|
|
163
|
+
},
|
|
164
|
+
async addCollaborator(playlistId, userId) {
|
|
165
|
+
try {
|
|
166
|
+
const response = await fetch(`${process.env.API_URL}/api/playlists/${playlistId}/collaborators/${userId}`, {
|
|
167
|
+
method: "POST"
|
|
168
|
+
});
|
|
169
|
+
const updatedPlaylist = await response.json();
|
|
170
|
+
if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {
|
|
171
|
+
state.currentPlaylist = updatedPlaylist;
|
|
172
|
+
}
|
|
173
|
+
return updatedPlaylist;
|
|
174
|
+
} catch (error) {
|
|
175
|
+
console.error("Error adding collaborator to playlist:", error);
|
|
176
|
+
throw error;
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
};
|
|
180
|
+
exports.actions = actions;
|
|
181
|
+
exports.state = state;
|
|
182
|
+
//# sourceMappingURL=playlists.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"playlists.cjs","sources":["../../../../../../src/modules/music/store/playlists.js"],"sourcesContent":["// store/playlists.js\nimport Store from '@martyrs/src/modules/globals/views/classes/globals.store.js';\nimport { reactive } from 'vue';\n\n// Create store instance\nconst playlistStore = new Store(`${process.env.API_URL}/api/playlists`);\n\n// State\nexport const state = reactive({\n playlists: [],\n featuredPlaylists: [],\n userPlaylists: [],\n currentPlaylist: null,\n currentPlaylistTracks: [],\n isLoading: false,\n loadingFeatured: false,\n});\n\n// Actions\nexport const actions = {\n async fetchPlaylists(options = {}) {\n state.isLoading = true;\n try {\n const playlists = await playlistStore.read(options);\n state.playlists = playlists;\n return playlists;\n } catch (error) {\n console.error('Error fetching playlists:', error);\n return [];\n } finally {\n state.isLoading = false;\n }\n },\n\n async fetchFeaturedPlaylists(options = {}) {\n state.loadingFeatured = true;\n try {\n // Обрабатываем options от Feed компонента\n const queryOptions = {\n limit: options.limit || 10,\n isPublic: true,\n };\n \n // Добавляем дополнительные параметры если есть\n if (options.skip) queryOptions.skip = options.skip;\n if (options.search) queryOptions.search = options.search;\n if (options.sortParam) queryOptions.sortParam = options.sortParam;\n if (options.sortOrder) queryOptions.sortOrder = options.sortOrder;\n \n // Если указан featured=true, добавляем соответствующий фильтр\n if (options.featured) {\n queryOptions.status = 'featured';\n // Или можно использовать sortParam для featured плейлистов\n queryOptions.sortParam = queryOptions.sortParam || 'followers';\n queryOptions.sortOrder = queryOptions.sortOrder || 'desc';\n }\n\n const playlists = await playlistStore.read(queryOptions);\n state.featuredPlaylists = playlists;\n return playlists;\n } catch (error) {\n console.error('Error fetching featured playlists:', error);\n return [];\n } finally {\n state.loadingFeatured = false;\n }\n },\n\n async fetchPlaylistByUrl(url) {\n try {\n const response = await fetch(`${process.env.API_URL}/api/playlists/url/${url}`);\n const playlist = await response.json();\n state.currentPlaylist = playlist;\n\n // Extract tracks from the playlist\n state.currentPlaylistTracks = playlist.tracks?.map(item => item.track) || [];\n\n return playlist;\n } catch (error) {\n console.error('Error fetching playlist by URL:', error);\n return null;\n }\n },\n\n async createPlaylist(playlistData) {\n try {\n const createdPlaylist = await playlistStore.create(playlistData);\n // Update local state\n state.playlists.unshift(createdPlaylist);\n state.userPlaylists.unshift(createdPlaylist);\n return createdPlaylist;\n } catch (error) {\n console.error('Error creating playlist:', error);\n throw error;\n }\n },\n\n async updatePlaylist(playlistData) {\n try {\n const updatedPlaylist = await playlistStore.update(playlistData);\n\n // Update local state\n const index = state.playlists.findIndex(p => p._id === updatedPlaylist._id);\n if (index !== -1) {\n state.playlists[index] = updatedPlaylist;\n }\n\n const userIndex = state.userPlaylists.findIndex(p => p._id === updatedPlaylist._id);\n if (userIndex !== -1) {\n state.userPlaylists[userIndex] = updatedPlaylist;\n }\n\n if (state.currentPlaylist && state.currentPlaylist._id === updatedPlaylist._id) {\n state.currentPlaylist = updatedPlaylist;\n }\n\n return updatedPlaylist;\n } catch (error) {\n console.error('Error updating playlist:', error);\n throw error;\n }\n },\n\n async deletePlaylist(playlistId) {\n try {\n await playlistStore.delete({ _id: playlistId });\n\n // Update local state\n state.playlists = state.playlists.filter(p => p._id !== playlistId);\n state.userPlaylists = state.userPlaylists.filter(p => p._id !== playlistId);\n\n if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {\n state.currentPlaylist = null;\n state.currentPlaylistTracks = [];\n }\n\n return true;\n } catch (error) {\n console.error('Error deleting playlist:', error);\n throw error;\n }\n },\n\n async fetchUserPlaylists(userId) {\n try {\n const response = await fetch(`${process.env.API_URL}/api/playlists/user/${userId || ''}`);\n const playlists = await response.json();\n state.userPlaylists = playlists;\n return playlists;\n } catch (error) {\n console.error('Error fetching user playlists:', error);\n return [];\n }\n },\n\n async addTrackToPlaylist(playlistId, trackId) {\n try {\n const response = await fetch(`${process.env.API_URL}/api/playlists/${playlistId}/tracks/${trackId}`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n });\n\n const updatedPlaylist = await response.json();\n\n // Update local state\n if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {\n state.currentPlaylist = updatedPlaylist;\n // Update tracks list\n const track = updatedPlaylist.tracks.find(item => item.track._id === trackId)?.track;\n if (track && !state.currentPlaylistTracks.some(t => t._id === trackId)) {\n state.currentPlaylistTracks.push(track);\n }\n }\n\n return updatedPlaylist;\n } catch (error) {\n console.error('Error adding track to playlist:', error);\n throw error;\n }\n },\n\n async removeTrackFromPlaylist(playlistId, trackId) {\n try {\n const response = await fetch(`${process.env.API_URL}/api/playlists/${playlistId}/tracks/${trackId}`, {\n method: 'DELETE',\n });\n\n const updatedPlaylist = await response.json();\n\n // Update local state\n if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {\n state.currentPlaylist = updatedPlaylist;\n state.currentPlaylistTracks = state.currentPlaylistTracks.filter(track => track._id !== trackId);\n }\n\n return updatedPlaylist;\n } catch (error) {\n console.error('Error removing track from playlist:', error);\n throw error;\n }\n },\n\n async addCollaborator(playlistId, userId) {\n try {\n const response = await fetch(`${process.env.API_URL}/api/playlists/${playlistId}/collaborators/${userId}`, {\n method: 'POST',\n });\n\n const updatedPlaylist = await response.json();\n\n // Update local state\n if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {\n state.currentPlaylist = updatedPlaylist;\n }\n\n return updatedPlaylist;\n } catch (error) {\n console.error('Error adding collaborator to playlist:', error);\n throw error;\n }\n },\n};\n"],"names":["Store","reactive"],"mappings":"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"}
|
|
@@ -0,0 +1,182 @@
|
|
|
1
|
+
import Store from "../../globals/views/classes/globals.store.js";
|
|
2
|
+
import { reactive } from "vue";
|
|
3
|
+
const playlistStore = new Store(`${process.env.API_URL}/api/playlists`);
|
|
4
|
+
const state = reactive({
|
|
5
|
+
playlists: [],
|
|
6
|
+
featuredPlaylists: [],
|
|
7
|
+
userPlaylists: [],
|
|
8
|
+
currentPlaylist: null,
|
|
9
|
+
currentPlaylistTracks: [],
|
|
10
|
+
isLoading: false,
|
|
11
|
+
loadingFeatured: false
|
|
12
|
+
});
|
|
13
|
+
const actions = {
|
|
14
|
+
async fetchPlaylists(options = {}) {
|
|
15
|
+
state.isLoading = true;
|
|
16
|
+
try {
|
|
17
|
+
const playlists = await playlistStore.read(options);
|
|
18
|
+
state.playlists = playlists;
|
|
19
|
+
return playlists;
|
|
20
|
+
} catch (error) {
|
|
21
|
+
console.error("Error fetching playlists:", error);
|
|
22
|
+
return [];
|
|
23
|
+
} finally {
|
|
24
|
+
state.isLoading = false;
|
|
25
|
+
}
|
|
26
|
+
},
|
|
27
|
+
async fetchFeaturedPlaylists(options = {}) {
|
|
28
|
+
state.loadingFeatured = true;
|
|
29
|
+
try {
|
|
30
|
+
const queryOptions = {
|
|
31
|
+
limit: options.limit || 10,
|
|
32
|
+
isPublic: true
|
|
33
|
+
};
|
|
34
|
+
if (options.skip) queryOptions.skip = options.skip;
|
|
35
|
+
if (options.search) queryOptions.search = options.search;
|
|
36
|
+
if (options.sortParam) queryOptions.sortParam = options.sortParam;
|
|
37
|
+
if (options.sortOrder) queryOptions.sortOrder = options.sortOrder;
|
|
38
|
+
if (options.featured) {
|
|
39
|
+
queryOptions.status = "featured";
|
|
40
|
+
queryOptions.sortParam = queryOptions.sortParam || "followers";
|
|
41
|
+
queryOptions.sortOrder = queryOptions.sortOrder || "desc";
|
|
42
|
+
}
|
|
43
|
+
const playlists = await playlistStore.read(queryOptions);
|
|
44
|
+
state.featuredPlaylists = playlists;
|
|
45
|
+
return playlists;
|
|
46
|
+
} catch (error) {
|
|
47
|
+
console.error("Error fetching featured playlists:", error);
|
|
48
|
+
return [];
|
|
49
|
+
} finally {
|
|
50
|
+
state.loadingFeatured = false;
|
|
51
|
+
}
|
|
52
|
+
},
|
|
53
|
+
async fetchPlaylistByUrl(url) {
|
|
54
|
+
var _a;
|
|
55
|
+
try {
|
|
56
|
+
const response = await fetch(`${process.env.API_URL}/api/playlists/url/${url}`);
|
|
57
|
+
const playlist = await response.json();
|
|
58
|
+
state.currentPlaylist = playlist;
|
|
59
|
+
state.currentPlaylistTracks = ((_a = playlist.tracks) == null ? void 0 : _a.map((item) => item.track)) || [];
|
|
60
|
+
return playlist;
|
|
61
|
+
} catch (error) {
|
|
62
|
+
console.error("Error fetching playlist by URL:", error);
|
|
63
|
+
return null;
|
|
64
|
+
}
|
|
65
|
+
},
|
|
66
|
+
async createPlaylist(playlistData) {
|
|
67
|
+
try {
|
|
68
|
+
const createdPlaylist = await playlistStore.create(playlistData);
|
|
69
|
+
state.playlists.unshift(createdPlaylist);
|
|
70
|
+
state.userPlaylists.unshift(createdPlaylist);
|
|
71
|
+
return createdPlaylist;
|
|
72
|
+
} catch (error) {
|
|
73
|
+
console.error("Error creating playlist:", error);
|
|
74
|
+
throw error;
|
|
75
|
+
}
|
|
76
|
+
},
|
|
77
|
+
async updatePlaylist(playlistData) {
|
|
78
|
+
try {
|
|
79
|
+
const updatedPlaylist = await playlistStore.update(playlistData);
|
|
80
|
+
const index = state.playlists.findIndex((p) => p._id === updatedPlaylist._id);
|
|
81
|
+
if (index !== -1) {
|
|
82
|
+
state.playlists[index] = updatedPlaylist;
|
|
83
|
+
}
|
|
84
|
+
const userIndex = state.userPlaylists.findIndex((p) => p._id === updatedPlaylist._id);
|
|
85
|
+
if (userIndex !== -1) {
|
|
86
|
+
state.userPlaylists[userIndex] = updatedPlaylist;
|
|
87
|
+
}
|
|
88
|
+
if (state.currentPlaylist && state.currentPlaylist._id === updatedPlaylist._id) {
|
|
89
|
+
state.currentPlaylist = updatedPlaylist;
|
|
90
|
+
}
|
|
91
|
+
return updatedPlaylist;
|
|
92
|
+
} catch (error) {
|
|
93
|
+
console.error("Error updating playlist:", error);
|
|
94
|
+
throw error;
|
|
95
|
+
}
|
|
96
|
+
},
|
|
97
|
+
async deletePlaylist(playlistId) {
|
|
98
|
+
try {
|
|
99
|
+
await playlistStore.delete({ _id: playlistId });
|
|
100
|
+
state.playlists = state.playlists.filter((p) => p._id !== playlistId);
|
|
101
|
+
state.userPlaylists = state.userPlaylists.filter((p) => p._id !== playlistId);
|
|
102
|
+
if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {
|
|
103
|
+
state.currentPlaylist = null;
|
|
104
|
+
state.currentPlaylistTracks = [];
|
|
105
|
+
}
|
|
106
|
+
return true;
|
|
107
|
+
} catch (error) {
|
|
108
|
+
console.error("Error deleting playlist:", error);
|
|
109
|
+
throw error;
|
|
110
|
+
}
|
|
111
|
+
},
|
|
112
|
+
async fetchUserPlaylists(userId) {
|
|
113
|
+
try {
|
|
114
|
+
const response = await fetch(`${process.env.API_URL}/api/playlists/user/${userId || ""}`);
|
|
115
|
+
const playlists = await response.json();
|
|
116
|
+
state.userPlaylists = playlists;
|
|
117
|
+
return playlists;
|
|
118
|
+
} catch (error) {
|
|
119
|
+
console.error("Error fetching user playlists:", error);
|
|
120
|
+
return [];
|
|
121
|
+
}
|
|
122
|
+
},
|
|
123
|
+
async addTrackToPlaylist(playlistId, trackId) {
|
|
124
|
+
var _a;
|
|
125
|
+
try {
|
|
126
|
+
const response = await fetch(`${process.env.API_URL}/api/playlists/${playlistId}/tracks/${trackId}`, {
|
|
127
|
+
method: "POST",
|
|
128
|
+
headers: {
|
|
129
|
+
"Content-Type": "application/json"
|
|
130
|
+
}
|
|
131
|
+
});
|
|
132
|
+
const updatedPlaylist = await response.json();
|
|
133
|
+
if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {
|
|
134
|
+
state.currentPlaylist = updatedPlaylist;
|
|
135
|
+
const track = (_a = updatedPlaylist.tracks.find((item) => item.track._id === trackId)) == null ? void 0 : _a.track;
|
|
136
|
+
if (track && !state.currentPlaylistTracks.some((t) => t._id === trackId)) {
|
|
137
|
+
state.currentPlaylistTracks.push(track);
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
return updatedPlaylist;
|
|
141
|
+
} catch (error) {
|
|
142
|
+
console.error("Error adding track to playlist:", error);
|
|
143
|
+
throw error;
|
|
144
|
+
}
|
|
145
|
+
},
|
|
146
|
+
async removeTrackFromPlaylist(playlistId, trackId) {
|
|
147
|
+
try {
|
|
148
|
+
const response = await fetch(`${process.env.API_URL}/api/playlists/${playlistId}/tracks/${trackId}`, {
|
|
149
|
+
method: "DELETE"
|
|
150
|
+
});
|
|
151
|
+
const updatedPlaylist = await response.json();
|
|
152
|
+
if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {
|
|
153
|
+
state.currentPlaylist = updatedPlaylist;
|
|
154
|
+
state.currentPlaylistTracks = state.currentPlaylistTracks.filter((track) => track._id !== trackId);
|
|
155
|
+
}
|
|
156
|
+
return updatedPlaylist;
|
|
157
|
+
} catch (error) {
|
|
158
|
+
console.error("Error removing track from playlist:", error);
|
|
159
|
+
throw error;
|
|
160
|
+
}
|
|
161
|
+
},
|
|
162
|
+
async addCollaborator(playlistId, userId) {
|
|
163
|
+
try {
|
|
164
|
+
const response = await fetch(`${process.env.API_URL}/api/playlists/${playlistId}/collaborators/${userId}`, {
|
|
165
|
+
method: "POST"
|
|
166
|
+
});
|
|
167
|
+
const updatedPlaylist = await response.json();
|
|
168
|
+
if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {
|
|
169
|
+
state.currentPlaylist = updatedPlaylist;
|
|
170
|
+
}
|
|
171
|
+
return updatedPlaylist;
|
|
172
|
+
} catch (error) {
|
|
173
|
+
console.error("Error adding collaborator to playlist:", error);
|
|
174
|
+
throw error;
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
};
|
|
178
|
+
export {
|
|
179
|
+
actions,
|
|
180
|
+
state
|
|
181
|
+
};
|
|
182
|
+
//# sourceMappingURL=playlists.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"playlists.js","sources":["../../../../../../src/modules/music/store/playlists.js"],"sourcesContent":["// store/playlists.js\nimport Store from '@martyrs/src/modules/globals/views/classes/globals.store.js';\nimport { reactive } from 'vue';\n\n// Create store instance\nconst playlistStore = new Store(`${process.env.API_URL}/api/playlists`);\n\n// State\nexport const state = reactive({\n playlists: [],\n featuredPlaylists: [],\n userPlaylists: [],\n currentPlaylist: null,\n currentPlaylistTracks: [],\n isLoading: false,\n loadingFeatured: false,\n});\n\n// Actions\nexport const actions = {\n async fetchPlaylists(options = {}) {\n state.isLoading = true;\n try {\n const playlists = await playlistStore.read(options);\n state.playlists = playlists;\n return playlists;\n } catch (error) {\n console.error('Error fetching playlists:', error);\n return [];\n } finally {\n state.isLoading = false;\n }\n },\n\n async fetchFeaturedPlaylists(options = {}) {\n state.loadingFeatured = true;\n try {\n // Обрабатываем options от Feed компонента\n const queryOptions = {\n limit: options.limit || 10,\n isPublic: true,\n };\n \n // Добавляем дополнительные параметры если есть\n if (options.skip) queryOptions.skip = options.skip;\n if (options.search) queryOptions.search = options.search;\n if (options.sortParam) queryOptions.sortParam = options.sortParam;\n if (options.sortOrder) queryOptions.sortOrder = options.sortOrder;\n \n // Если указан featured=true, добавляем соответствующий фильтр\n if (options.featured) {\n queryOptions.status = 'featured';\n // Или можно использовать sortParam для featured плейлистов\n queryOptions.sortParam = queryOptions.sortParam || 'followers';\n queryOptions.sortOrder = queryOptions.sortOrder || 'desc';\n }\n\n const playlists = await playlistStore.read(queryOptions);\n state.featuredPlaylists = playlists;\n return playlists;\n } catch (error) {\n console.error('Error fetching featured playlists:', error);\n return [];\n } finally {\n state.loadingFeatured = false;\n }\n },\n\n async fetchPlaylistByUrl(url) {\n try {\n const response = await fetch(`${process.env.API_URL}/api/playlists/url/${url}`);\n const playlist = await response.json();\n state.currentPlaylist = playlist;\n\n // Extract tracks from the playlist\n state.currentPlaylistTracks = playlist.tracks?.map(item => item.track) || [];\n\n return playlist;\n } catch (error) {\n console.error('Error fetching playlist by URL:', error);\n return null;\n }\n },\n\n async createPlaylist(playlistData) {\n try {\n const createdPlaylist = await playlistStore.create(playlistData);\n // Update local state\n state.playlists.unshift(createdPlaylist);\n state.userPlaylists.unshift(createdPlaylist);\n return createdPlaylist;\n } catch (error) {\n console.error('Error creating playlist:', error);\n throw error;\n }\n },\n\n async updatePlaylist(playlistData) {\n try {\n const updatedPlaylist = await playlistStore.update(playlistData);\n\n // Update local state\n const index = state.playlists.findIndex(p => p._id === updatedPlaylist._id);\n if (index !== -1) {\n state.playlists[index] = updatedPlaylist;\n }\n\n const userIndex = state.userPlaylists.findIndex(p => p._id === updatedPlaylist._id);\n if (userIndex !== -1) {\n state.userPlaylists[userIndex] = updatedPlaylist;\n }\n\n if (state.currentPlaylist && state.currentPlaylist._id === updatedPlaylist._id) {\n state.currentPlaylist = updatedPlaylist;\n }\n\n return updatedPlaylist;\n } catch (error) {\n console.error('Error updating playlist:', error);\n throw error;\n }\n },\n\n async deletePlaylist(playlistId) {\n try {\n await playlistStore.delete({ _id: playlistId });\n\n // Update local state\n state.playlists = state.playlists.filter(p => p._id !== playlistId);\n state.userPlaylists = state.userPlaylists.filter(p => p._id !== playlistId);\n\n if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {\n state.currentPlaylist = null;\n state.currentPlaylistTracks = [];\n }\n\n return true;\n } catch (error) {\n console.error('Error deleting playlist:', error);\n throw error;\n }\n },\n\n async fetchUserPlaylists(userId) {\n try {\n const response = await fetch(`${process.env.API_URL}/api/playlists/user/${userId || ''}`);\n const playlists = await response.json();\n state.userPlaylists = playlists;\n return playlists;\n } catch (error) {\n console.error('Error fetching user playlists:', error);\n return [];\n }\n },\n\n async addTrackToPlaylist(playlistId, trackId) {\n try {\n const response = await fetch(`${process.env.API_URL}/api/playlists/${playlistId}/tracks/${trackId}`, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n },\n });\n\n const updatedPlaylist = await response.json();\n\n // Update local state\n if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {\n state.currentPlaylist = updatedPlaylist;\n // Update tracks list\n const track = updatedPlaylist.tracks.find(item => item.track._id === trackId)?.track;\n if (track && !state.currentPlaylistTracks.some(t => t._id === trackId)) {\n state.currentPlaylistTracks.push(track);\n }\n }\n\n return updatedPlaylist;\n } catch (error) {\n console.error('Error adding track to playlist:', error);\n throw error;\n }\n },\n\n async removeTrackFromPlaylist(playlistId, trackId) {\n try {\n const response = await fetch(`${process.env.API_URL}/api/playlists/${playlistId}/tracks/${trackId}`, {\n method: 'DELETE',\n });\n\n const updatedPlaylist = await response.json();\n\n // Update local state\n if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {\n state.currentPlaylist = updatedPlaylist;\n state.currentPlaylistTracks = state.currentPlaylistTracks.filter(track => track._id !== trackId);\n }\n\n return updatedPlaylist;\n } catch (error) {\n console.error('Error removing track from playlist:', error);\n throw error;\n }\n },\n\n async addCollaborator(playlistId, userId) {\n try {\n const response = await fetch(`${process.env.API_URL}/api/playlists/${playlistId}/collaborators/${userId}`, {\n method: 'POST',\n });\n\n const updatedPlaylist = await response.json();\n\n // Update local state\n if (state.currentPlaylist && state.currentPlaylist._id === playlistId) {\n state.currentPlaylist = updatedPlaylist;\n }\n\n return updatedPlaylist;\n } catch (error) {\n console.error('Error adding collaborator to playlist:', error);\n throw error;\n }\n },\n};\n"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
+
const vue = require("vue");
|
|
4
|
+
const state = vue.reactive({
|
|
5
|
+
query: "",
|
|
6
|
+
results: {
|
|
7
|
+
tracks: [],
|
|
8
|
+
albums: [],
|
|
9
|
+
artists: [],
|
|
10
|
+
playlists: [],
|
|
11
|
+
genres: []
|
|
12
|
+
},
|
|
13
|
+
isLoading: false,
|
|
14
|
+
error: null,
|
|
15
|
+
activeFilter: "all"
|
|
16
|
+
// 'all', 'tracks', 'albums', 'artists', 'playlists', 'genres'
|
|
17
|
+
});
|
|
18
|
+
const actions = {
|
|
19
|
+
async search(query, type = null, limit = 10) {
|
|
20
|
+
if (!query || query.length < 2) {
|
|
21
|
+
state.results = {
|
|
22
|
+
tracks: [],
|
|
23
|
+
albums: [],
|
|
24
|
+
artists: [],
|
|
25
|
+
playlists: [],
|
|
26
|
+
genres: []
|
|
27
|
+
};
|
|
28
|
+
state.error = "Search query must be at least 2 characters";
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
state.query = query;
|
|
32
|
+
state.isLoading = true;
|
|
33
|
+
state.error = null;
|
|
34
|
+
try {
|
|
35
|
+
const queryParams = new URLSearchParams({
|
|
36
|
+
query,
|
|
37
|
+
limit
|
|
38
|
+
});
|
|
39
|
+
if (type) {
|
|
40
|
+
queryParams.append("type", type);
|
|
41
|
+
}
|
|
42
|
+
const response = await fetch(`${process.env.API_URL}/api/music/search?${queryParams.toString()}`);
|
|
43
|
+
if (!response.ok) {
|
|
44
|
+
throw new Error("Search request failed");
|
|
45
|
+
}
|
|
46
|
+
const data = await response.json();
|
|
47
|
+
state.results = {
|
|
48
|
+
tracks: data.tracks || [],
|
|
49
|
+
albums: data.albums || [],
|
|
50
|
+
artists: data.artists || [],
|
|
51
|
+
playlists: data.playlists || [],
|
|
52
|
+
genres: data.genres || []
|
|
53
|
+
};
|
|
54
|
+
} catch (error) {
|
|
55
|
+
console.error("Search error:", error);
|
|
56
|
+
state.error = error.message;
|
|
57
|
+
state.results = {
|
|
58
|
+
tracks: [],
|
|
59
|
+
albums: [],
|
|
60
|
+
artists: [],
|
|
61
|
+
playlists: [],
|
|
62
|
+
genres: []
|
|
63
|
+
};
|
|
64
|
+
} finally {
|
|
65
|
+
state.isLoading = false;
|
|
66
|
+
}
|
|
67
|
+
},
|
|
68
|
+
setFilter(filter) {
|
|
69
|
+
state.activeFilter = filter;
|
|
70
|
+
},
|
|
71
|
+
clearSearch() {
|
|
72
|
+
state.query = "";
|
|
73
|
+
state.results = {
|
|
74
|
+
tracks: [],
|
|
75
|
+
albums: [],
|
|
76
|
+
artists: [],
|
|
77
|
+
playlists: [],
|
|
78
|
+
genres: []
|
|
79
|
+
};
|
|
80
|
+
state.error = null;
|
|
81
|
+
state.isLoading = false;
|
|
82
|
+
}
|
|
83
|
+
};
|
|
84
|
+
const computed = {
|
|
85
|
+
hasResults: () => {
|
|
86
|
+
return Object.values(state.results).some((arr) => arr.length > 0);
|
|
87
|
+
},
|
|
88
|
+
filteredResults: () => {
|
|
89
|
+
if (state.activeFilter === "all") {
|
|
90
|
+
return state.results;
|
|
91
|
+
}
|
|
92
|
+
const filtered = {
|
|
93
|
+
tracks: [],
|
|
94
|
+
albums: [],
|
|
95
|
+
artists: [],
|
|
96
|
+
playlists: [],
|
|
97
|
+
genres: []
|
|
98
|
+
};
|
|
99
|
+
filtered[state.activeFilter] = state.results[state.activeFilter];
|
|
100
|
+
return filtered;
|
|
101
|
+
},
|
|
102
|
+
totalResultsCount: () => {
|
|
103
|
+
return Object.values(state.results).reduce((sum, arr) => sum + arr.length, 0);
|
|
104
|
+
}
|
|
105
|
+
};
|
|
106
|
+
exports.actions = actions;
|
|
107
|
+
exports.computed = computed;
|
|
108
|
+
exports.state = state;
|
|
109
|
+
//# sourceMappingURL=search.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"search.cjs","sources":["../../../../../../src/modules/music/store/search.js"],"sourcesContent":["// store/search.js\nimport { reactive } from 'vue';\n\n// State\nexport const state = reactive({\n query: '',\n results: {\n tracks: [],\n albums: [],\n artists: [],\n playlists: [],\n genres: [],\n },\n isLoading: false,\n error: null,\n activeFilter: 'all', // 'all', 'tracks', 'albums', 'artists', 'playlists', 'genres'\n});\n\n// Actions\nexport const actions = {\n async search(query, type = null, limit = 10) {\n if (!query || query.length < 2) {\n // Reset results if query is too short\n state.results = {\n tracks: [],\n albums: [],\n artists: [],\n playlists: [],\n genres: [],\n };\n state.error = 'Search query must be at least 2 characters';\n return;\n }\n\n state.query = query;\n state.isLoading = true;\n state.error = null;\n\n try {\n const queryParams = new URLSearchParams({\n query,\n limit,\n });\n\n if (type) {\n queryParams.append('type', type);\n }\n\n const response = await fetch(`${process.env.API_URL}/api/music/search?${queryParams.toString()}`);\n\n if (!response.ok) {\n throw new Error('Search request failed');\n }\n\n const data = await response.json();\n\n // Update state with results\n state.results = {\n tracks: data.tracks || [],\n albums: data.albums || [],\n artists: data.artists || [],\n playlists: data.playlists || [],\n genres: data.genres || [],\n };\n } catch (error) {\n console.error('Search error:', error);\n state.error = error.message;\n // Clear results on error\n state.results = {\n tracks: [],\n albums: [],\n artists: [],\n playlists: [],\n genres: [],\n };\n } finally {\n state.isLoading = false;\n }\n },\n\n setFilter(filter) {\n state.activeFilter = filter;\n },\n\n clearSearch() {\n state.query = '';\n state.results = {\n tracks: [],\n albums: [],\n artists: [],\n playlists: [],\n genres: [],\n };\n state.error = null;\n state.isLoading = false;\n },\n};\n\n// Computed values\nexport const computed = {\n hasResults: () => {\n return Object.values(state.results).some(arr => arr.length > 0);\n },\n\n filteredResults: () => {\n if (state.activeFilter === 'all') {\n return state.results;\n }\n\n // Return only the filtered category\n const filtered = {\n tracks: [],\n albums: [],\n artists: [],\n playlists: [],\n genres: [],\n };\n\n filtered[state.activeFilter] = state.results[state.activeFilter];\n return filtered;\n },\n\n totalResultsCount: () => {\n return Object.values(state.results).reduce((sum, arr) => sum + arr.length, 0);\n },\n};\n"],"names":["reactive"],"mappings":";;;AAIY,MAAC,QAAQA,IAAAA,SAAS;AAAA,EAC5B,OAAO;AAAA,EACP,SAAS;AAAA,IACP,QAAQ,CAAE;AAAA,IACV,QAAQ,CAAE;AAAA,IACV,SAAS,CAAE;AAAA,IACX,WAAW,CAAE;AAAA,IACb,QAAQ,CAAE;AAAA,EACX;AAAA,EACD,WAAW;AAAA,EACX,OAAO;AAAA,EACP,cAAc;AAAA;AAChB,CAAC;AAGW,MAAC,UAAU;AAAA,EACrB,MAAM,OAAO,OAAO,OAAO,MAAM,QAAQ,IAAI;AAC3C,QAAI,CAAC,SAAS,MAAM,SAAS,GAAG;AAE9B,YAAM,UAAU;AAAA,QACd,QAAQ,CAAE;AAAA,QACV,QAAQ,CAAE;AAAA,QACV,SAAS,CAAE;AAAA,QACX,WAAW,CAAE;AAAA,QACb,QAAQ,CAAE;AAAA,MACX;AACD,YAAM,QAAQ;AACd;AAAA,IACN;AAEI,UAAM,QAAQ;AACd,UAAM,YAAY;AAClB,UAAM,QAAQ;AAEd,QAAI;AACF,YAAM,cAAc,IAAI,gBAAgB;AAAA,QACtC;AAAA,QACA;AAAA,MACR,CAAO;AAED,UAAI,MAAM;AACR,oBAAY,OAAO,QAAQ,IAAI;AAAA,MACvC;AAEM,YAAM,WAAW,MAAM,MAAM,GAAG,QAAQ,IAAI,OAAO,qBAAqB,YAAY,SAAQ,CAAE,EAAE;AAEhG,UAAI,CAAC,SAAS,IAAI;AAChB,cAAM,IAAI,MAAM,uBAAuB;AAAA,MAC/C;AAEM,YAAM,OAAO,MAAM,SAAS,KAAM;AAGlC,YAAM,UAAU;AAAA,QACd,QAAQ,KAAK,UAAU,CAAE;AAAA,QACzB,QAAQ,KAAK,UAAU,CAAE;AAAA,QACzB,SAAS,KAAK,WAAW,CAAE;AAAA,QAC3B,WAAW,KAAK,aAAa,CAAE;AAAA,QAC/B,QAAQ,KAAK,UAAU,CAAE;AAAA,MAC1B;AAAA,IACF,SAAQ,OAAO;AACd,cAAQ,MAAM,iBAAiB,KAAK;AACpC,YAAM,QAAQ,MAAM;AAEpB,YAAM,UAAU;AAAA,QACd,QAAQ,CAAE;AAAA,QACV,QAAQ,CAAE;AAAA,QACV,SAAS,CAAE;AAAA,QACX,WAAW,CAAE;AAAA,QACb,QAAQ,CAAE;AAAA,MACX;AAAA,IACP,UAAc;AACR,YAAM,YAAY;AAAA,IACxB;AAAA,EACG;AAAA,EAED,UAAU,QAAQ;AAChB,UAAM,eAAe;AAAA,EACtB;AAAA,EAED,cAAc;AACZ,UAAM,QAAQ;AACd,UAAM,UAAU;AAAA,MACd,QAAQ,CAAE;AAAA,MACV,QAAQ,CAAE;AAAA,MACV,SAAS,CAAE;AAAA,MACX,WAAW,CAAE;AAAA,MACb,QAAQ,CAAE;AAAA,IACX;AACD,UAAM,QAAQ;AACd,UAAM,YAAY;AAAA,EACnB;AACH;AAGY,MAAC,WAAW;AAAA,EACtB,YAAY,MAAM;AAChB,WAAO,OAAO,OAAO,MAAM,OAAO,EAAE,KAAK,SAAO,IAAI,SAAS,CAAC;AAAA,EAC/D;AAAA,EAED,iBAAiB,MAAM;AACrB,QAAI,MAAM,iBAAiB,OAAO;AAChC,aAAO,MAAM;AAAA,IACnB;AAGI,UAAM,WAAW;AAAA,MACf,QAAQ,CAAE;AAAA,MACV,QAAQ,CAAE;AAAA,MACV,SAAS,CAAE;AAAA,MACX,WAAW,CAAE;AAAA,MACb,QAAQ,CAAE;AAAA,IACX;AAED,aAAS,MAAM,YAAY,IAAI,MAAM,QAAQ,MAAM,YAAY;AAC/D,WAAO;AAAA,EACR;AAAA,EAED,mBAAmB,MAAM;AACvB,WAAO,OAAO,OAAO,MAAM,OAAO,EAAE,OAAO,CAAC,KAAK,QAAQ,MAAM,IAAI,QAAQ,CAAC;AAAA,EAC7E;AACH;;;;"}
|
|
@@ -0,0 +1,109 @@
|
|
|
1
|
+
import { reactive } from "vue";
|
|
2
|
+
const state = reactive({
|
|
3
|
+
query: "",
|
|
4
|
+
results: {
|
|
5
|
+
tracks: [],
|
|
6
|
+
albums: [],
|
|
7
|
+
artists: [],
|
|
8
|
+
playlists: [],
|
|
9
|
+
genres: []
|
|
10
|
+
},
|
|
11
|
+
isLoading: false,
|
|
12
|
+
error: null,
|
|
13
|
+
activeFilter: "all"
|
|
14
|
+
// 'all', 'tracks', 'albums', 'artists', 'playlists', 'genres'
|
|
15
|
+
});
|
|
16
|
+
const actions = {
|
|
17
|
+
async search(query, type = null, limit = 10) {
|
|
18
|
+
if (!query || query.length < 2) {
|
|
19
|
+
state.results = {
|
|
20
|
+
tracks: [],
|
|
21
|
+
albums: [],
|
|
22
|
+
artists: [],
|
|
23
|
+
playlists: [],
|
|
24
|
+
genres: []
|
|
25
|
+
};
|
|
26
|
+
state.error = "Search query must be at least 2 characters";
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
state.query = query;
|
|
30
|
+
state.isLoading = true;
|
|
31
|
+
state.error = null;
|
|
32
|
+
try {
|
|
33
|
+
const queryParams = new URLSearchParams({
|
|
34
|
+
query,
|
|
35
|
+
limit
|
|
36
|
+
});
|
|
37
|
+
if (type) {
|
|
38
|
+
queryParams.append("type", type);
|
|
39
|
+
}
|
|
40
|
+
const response = await fetch(`${process.env.API_URL}/api/music/search?${queryParams.toString()}`);
|
|
41
|
+
if (!response.ok) {
|
|
42
|
+
throw new Error("Search request failed");
|
|
43
|
+
}
|
|
44
|
+
const data = await response.json();
|
|
45
|
+
state.results = {
|
|
46
|
+
tracks: data.tracks || [],
|
|
47
|
+
albums: data.albums || [],
|
|
48
|
+
artists: data.artists || [],
|
|
49
|
+
playlists: data.playlists || [],
|
|
50
|
+
genres: data.genres || []
|
|
51
|
+
};
|
|
52
|
+
} catch (error) {
|
|
53
|
+
console.error("Search error:", error);
|
|
54
|
+
state.error = error.message;
|
|
55
|
+
state.results = {
|
|
56
|
+
tracks: [],
|
|
57
|
+
albums: [],
|
|
58
|
+
artists: [],
|
|
59
|
+
playlists: [],
|
|
60
|
+
genres: []
|
|
61
|
+
};
|
|
62
|
+
} finally {
|
|
63
|
+
state.isLoading = false;
|
|
64
|
+
}
|
|
65
|
+
},
|
|
66
|
+
setFilter(filter) {
|
|
67
|
+
state.activeFilter = filter;
|
|
68
|
+
},
|
|
69
|
+
clearSearch() {
|
|
70
|
+
state.query = "";
|
|
71
|
+
state.results = {
|
|
72
|
+
tracks: [],
|
|
73
|
+
albums: [],
|
|
74
|
+
artists: [],
|
|
75
|
+
playlists: [],
|
|
76
|
+
genres: []
|
|
77
|
+
};
|
|
78
|
+
state.error = null;
|
|
79
|
+
state.isLoading = false;
|
|
80
|
+
}
|
|
81
|
+
};
|
|
82
|
+
const computed = {
|
|
83
|
+
hasResults: () => {
|
|
84
|
+
return Object.values(state.results).some((arr) => arr.length > 0);
|
|
85
|
+
},
|
|
86
|
+
filteredResults: () => {
|
|
87
|
+
if (state.activeFilter === "all") {
|
|
88
|
+
return state.results;
|
|
89
|
+
}
|
|
90
|
+
const filtered = {
|
|
91
|
+
tracks: [],
|
|
92
|
+
albums: [],
|
|
93
|
+
artists: [],
|
|
94
|
+
playlists: [],
|
|
95
|
+
genres: []
|
|
96
|
+
};
|
|
97
|
+
filtered[state.activeFilter] = state.results[state.activeFilter];
|
|
98
|
+
return filtered;
|
|
99
|
+
},
|
|
100
|
+
totalResultsCount: () => {
|
|
101
|
+
return Object.values(state.results).reduce((sum, arr) => sum + arr.length, 0);
|
|
102
|
+
}
|
|
103
|
+
};
|
|
104
|
+
export {
|
|
105
|
+
actions,
|
|
106
|
+
computed,
|
|
107
|
+
state
|
|
108
|
+
};
|
|
109
|
+
//# sourceMappingURL=search.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"search.js","sources":["../../../../../../src/modules/music/store/search.js"],"sourcesContent":["// store/search.js\nimport { reactive } from 'vue';\n\n// State\nexport const state = reactive({\n query: '',\n results: {\n tracks: [],\n albums: [],\n artists: [],\n playlists: [],\n genres: [],\n },\n isLoading: false,\n error: null,\n activeFilter: 'all', // 'all', 'tracks', 'albums', 'artists', 'playlists', 'genres'\n});\n\n// Actions\nexport const actions = {\n async search(query, type = null, limit = 10) {\n if (!query || query.length < 2) {\n // Reset results if query is too short\n state.results = {\n tracks: [],\n albums: [],\n artists: [],\n playlists: [],\n genres: [],\n };\n state.error = 'Search query must be at least 2 characters';\n return;\n }\n\n state.query = query;\n state.isLoading = true;\n state.error = null;\n\n try {\n const queryParams = new URLSearchParams({\n query,\n limit,\n });\n\n if (type) {\n queryParams.append('type', type);\n }\n\n const response = await fetch(`${process.env.API_URL}/api/music/search?${queryParams.toString()}`);\n\n if (!response.ok) {\n throw new Error('Search request failed');\n }\n\n const data = await response.json();\n\n // Update state with results\n state.results = {\n tracks: data.tracks || [],\n albums: data.albums || [],\n artists: data.artists || [],\n playlists: data.playlists || [],\n genres: data.genres || [],\n };\n } catch (error) {\n console.error('Search error:', error);\n state.error = error.message;\n // Clear results on error\n state.results = {\n tracks: [],\n albums: [],\n artists: [],\n playlists: [],\n genres: [],\n };\n } finally {\n state.isLoading = false;\n }\n },\n\n setFilter(filter) {\n state.activeFilter = filter;\n },\n\n clearSearch() {\n state.query = '';\n state.results = {\n tracks: [],\n albums: [],\n artists: [],\n playlists: [],\n genres: [],\n };\n state.error = null;\n state.isLoading = false;\n },\n};\n\n// Computed values\nexport const computed = {\n hasResults: () => {\n return Object.values(state.results).some(arr => arr.length > 0);\n },\n\n filteredResults: () => {\n if (state.activeFilter === 'all') {\n return state.results;\n }\n\n // Return only the filtered category\n const filtered = {\n tracks: [],\n albums: [],\n artists: [],\n playlists: [],\n genres: [],\n };\n\n filtered[state.activeFilter] = state.results[state.activeFilter];\n return filtered;\n },\n\n totalResultsCount: () => {\n return Object.values(state.results).reduce((sum, arr) => sum + arr.length, 0);\n },\n};\n"],"names":[],"mappings":";AAIY,MAAC,QAAQ,SAAS;AAAA,EAC5B,OAAO;AAAA,EACP,SAAS;AAAA,IACP,QAAQ,CAAE;AAAA,IACV,QAAQ,CAAE;AAAA,IACV,SAAS,CAAE;AAAA,IACX,WAAW,CAAE;AAAA,IACb,QAAQ,CAAE;AAAA,EACX;AAAA,EACD,WAAW;AAAA,EACX,OAAO;AAAA,EACP,cAAc;AAAA;AAChB,CAAC;AAGW,MAAC,UAAU;AAAA,EACrB,MAAM,OAAO,OAAO,OAAO,MAAM,QAAQ,IAAI;AAC3C,QAAI,CAAC,SAAS,MAAM,SAAS,GAAG;AAE9B,YAAM,UAAU;AAAA,QACd,QAAQ,CAAE;AAAA,QACV,QAAQ,CAAE;AAAA,QACV,SAAS,CAAE;AAAA,QACX,WAAW,CAAE;AAAA,QACb,QAAQ,CAAE;AAAA,MACX;AACD,YAAM,QAAQ;AACd;AAAA,IACN;AAEI,UAAM,QAAQ;AACd,UAAM,YAAY;AAClB,UAAM,QAAQ;AAEd,QAAI;AACF,YAAM,cAAc,IAAI,gBAAgB;AAAA,QACtC;AAAA,QACA;AAAA,MACR,CAAO;AAED,UAAI,MAAM;AACR,oBAAY,OAAO,QAAQ,IAAI;AAAA,MACvC;AAEM,YAAM,WAAW,MAAM,MAAM,GAAG,QAAQ,IAAI,OAAO,qBAAqB,YAAY,SAAQ,CAAE,EAAE;AAEhG,UAAI,CAAC,SAAS,IAAI;AAChB,cAAM,IAAI,MAAM,uBAAuB;AAAA,MAC/C;AAEM,YAAM,OAAO,MAAM,SAAS,KAAM;AAGlC,YAAM,UAAU;AAAA,QACd,QAAQ,KAAK,UAAU,CAAE;AAAA,QACzB,QAAQ,KAAK,UAAU,CAAE;AAAA,QACzB,SAAS,KAAK,WAAW,CAAE;AAAA,QAC3B,WAAW,KAAK,aAAa,CAAE;AAAA,QAC/B,QAAQ,KAAK,UAAU,CAAE;AAAA,MAC1B;AAAA,IACF,SAAQ,OAAO;AACd,cAAQ,MAAM,iBAAiB,KAAK;AACpC,YAAM,QAAQ,MAAM;AAEpB,YAAM,UAAU;AAAA,QACd,QAAQ,CAAE;AAAA,QACV,QAAQ,CAAE;AAAA,QACV,SAAS,CAAE;AAAA,QACX,WAAW,CAAE;AAAA,QACb,QAAQ,CAAE;AAAA,MACX;AAAA,IACP,UAAc;AACR,YAAM,YAAY;AAAA,IACxB;AAAA,EACG;AAAA,EAED,UAAU,QAAQ;AAChB,UAAM,eAAe;AAAA,EACtB;AAAA,EAED,cAAc;AACZ,UAAM,QAAQ;AACd,UAAM,UAAU;AAAA,MACd,QAAQ,CAAE;AAAA,MACV,QAAQ,CAAE;AAAA,MACV,SAAS,CAAE;AAAA,MACX,WAAW,CAAE;AAAA,MACb,QAAQ,CAAE;AAAA,IACX;AACD,UAAM,QAAQ;AACd,UAAM,YAAY;AAAA,EACnB;AACH;AAGY,MAAC,WAAW;AAAA,EACtB,YAAY,MAAM;AAChB,WAAO,OAAO,OAAO,MAAM,OAAO,EAAE,KAAK,SAAO,IAAI,SAAS,CAAC;AAAA,EAC/D;AAAA,EAED,iBAAiB,MAAM;AACrB,QAAI,MAAM,iBAAiB,OAAO;AAChC,aAAO,MAAM;AAAA,IACnB;AAGI,UAAM,WAAW;AAAA,MACf,QAAQ,CAAE;AAAA,MACV,QAAQ,CAAE;AAAA,MACV,SAAS,CAAE;AAAA,MACX,WAAW,CAAE;AAAA,MACb,QAAQ,CAAE;AAAA,IACX;AAED,aAAS,MAAM,YAAY,IAAI,MAAM,QAAQ,MAAM,YAAY;AAC/D,WAAO;AAAA,EACR;AAAA,EAED,mBAAmB,MAAM;AACvB,WAAO,OAAO,OAAO,MAAM,OAAO,EAAE,OAAO,CAAC,KAAK,QAAQ,MAAM,IAAI,QAAQ,CAAC;AAAA,EAC7E;AACH;"}
|