@ozdao/martyrs 0.2.582 → 0.2.584

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (226) hide show
  1. package/dist/{main-vq1_XpmQ.js → main-fmp55tJF.js} +11 -11
  2. package/dist/martyrs/dist/{main-vq1_XpmQ.js → main-fmp55tJF.js} +2 -2
  3. package/dist/martyrs/dist/main-fmp55tJF.js.map +1 -0
  4. package/dist/martyrs/dist/{web-BNJDRie_.js → web-BDuQSQKS.js} +2 -2
  5. package/dist/martyrs/dist/{web-BNJDRie_.js.map → web-BDuQSQKS.js.map} +1 -1
  6. package/dist/martyrs/src/components/Button/{Button.vue.js → Button.vue2.js} +2 -2
  7. package/dist/martyrs/src/components/Button/Button.vue2.js.map +1 -0
  8. package/dist/martyrs/src/components/Calendar/Calendar.vue2.js +5 -5
  9. package/dist/martyrs/src/components/Calendar/Calendar.vue2.js.map +1 -1
  10. package/dist/martyrs/src/components/EditImages/{EditImages.vue.js → EditImages.vue2.js} +2 -2
  11. package/dist/martyrs/src/components/EditImages/EditImages.vue2.js.map +1 -0
  12. package/dist/martyrs/src/components/Feed/Feed.vue.js +1 -1
  13. package/dist/martyrs/src/components/Field/Field.vue.js +2 -2
  14. package/dist/martyrs/src/components/Field/Field.vue.js.map +1 -1
  15. package/dist/martyrs/src/components/FieldBig/FieldBig.vue.js +2 -2
  16. package/dist/martyrs/src/components/FieldBig/FieldBig.vue.js.map +1 -1
  17. package/dist/martyrs/src/components/FieldDate/FieldDate.vue.js +2 -2
  18. package/dist/martyrs/src/components/FieldDate/FieldDate.vue.js.map +1 -1
  19. package/dist/martyrs/src/components/Select/{Select.vue2.js → Select.vue.js} +2 -2
  20. package/dist/martyrs/src/components/Select/Select.vue.js.map +1 -0
  21. package/dist/martyrs/src/components/Spoiler/{Spoiler.vue.js → Spoiler.vue2.js} +2 -2
  22. package/dist/martyrs/src/components/Spoiler/Spoiler.vue2.js.map +1 -0
  23. package/dist/martyrs/src/modules/auth/views/components/pages/EnterPassword.vue.js +1 -1
  24. package/dist/martyrs/src/modules/auth/views/components/pages/Invite.vue.js +1 -1
  25. package/dist/martyrs/src/modules/auth/views/components/pages/Profile.vue.js +7 -13
  26. package/dist/martyrs/src/modules/auth/views/components/pages/Profile.vue.js.map +1 -1
  27. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditAccount.vue.js +1 -1
  28. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditProfile.vue.js +1 -1
  29. package/dist/martyrs/src/modules/auth/views/components/pages/ResetPassword.vue.js +1 -1
  30. package/dist/martyrs/src/modules/auth/views/components/pages/SignIn.vue.js +1 -1
  31. package/dist/martyrs/src/modules/auth/views/components/pages/SignUp.vue.js +1 -1
  32. package/dist/martyrs/src/modules/auth/views/components/pages/UserDashboard.vue.js +182 -89
  33. package/dist/martyrs/src/modules/auth/views/components/pages/UserDashboard.vue.js.map +1 -1
  34. package/dist/martyrs/src/modules/auth/views/components/sections/ProfileEditCredentials.vue.js +1 -1
  35. package/dist/martyrs/src/modules/auth/views/configs/navigation.user.config.js +9 -2
  36. package/dist/martyrs/src/modules/auth/views/configs/navigation.user.config.js.map +1 -1
  37. package/dist/martyrs/src/modules/community/components/layouts/Community.vue.js +3 -3
  38. package/dist/martyrs/src/modules/community/components/layouts/Community.vue.js.map +1 -1
  39. package/dist/martyrs/src/modules/community/components/pages/BlogPost.vue.js +1 -1
  40. package/dist/martyrs/src/modules/community/components/pages/CreateBlogPost.vue.js +1 -1
  41. package/dist/martyrs/src/modules/core/views/components/blocks/CardHeader.vue.js +2 -2
  42. package/dist/martyrs/src/modules/core/views/components/blocks/CardHeader.vue.js.map +1 -1
  43. package/dist/martyrs/src/modules/core/views/components/blocks/PopupAuth.vue.js +1 -1
  44. package/dist/martyrs/src/modules/core/views/components/blocks/PopupDateSelector.vue.js +1 -1
  45. package/dist/martyrs/src/modules/core/views/components/layouts/Client.vue.js +1 -1
  46. package/dist/martyrs/src/modules/core/views/components/partials/Header.vue.js +3 -3
  47. package/dist/martyrs/src/modules/core/views/components/partials/Header.vue.js.map +1 -1
  48. package/dist/martyrs/src/modules/core/views/components/partials/Navigation.vue.js +1 -1
  49. package/dist/martyrs/src/modules/core/views/components/partials/NavigationBar.vue.js +1 -1
  50. package/dist/martyrs/src/modules/core/views/components/partials/Sidebar.vue.js +2 -2
  51. package/dist/martyrs/src/modules/core/views/components/partials/Sidebar.vue.js.map +1 -1
  52. package/dist/martyrs/src/modules/core/views/components/sections/{Filters.vue.js → Filters.vue2.js} +5 -5
  53. package/dist/martyrs/src/modules/core/views/components/sections/Filters.vue2.js.map +1 -0
  54. package/dist/martyrs/src/modules/core/views/components/sections/SectionPageTitle.vue.js +1 -1
  55. package/dist/martyrs/src/modules/core/views/components/sections/SectionPageTitle.vue.js.map +1 -1
  56. package/dist/martyrs/src/modules/events/components/elements/ButtonCheck.vue.js +1 -1
  57. package/dist/martyrs/src/modules/events/components/elements/ButtonJoin.vue.js +1 -1
  58. package/dist/martyrs/src/modules/events/components/pages/EditEvent.vue.js +2 -2
  59. package/dist/martyrs/src/modules/events/components/pages/EditEventTickets.vue.js +3 -3
  60. package/dist/martyrs/src/modules/events/components/pages/EditEventTickets.vue.js.map +1 -1
  61. package/dist/martyrs/src/modules/events/components/pages/Event.vue.js +1 -1
  62. package/dist/martyrs/src/modules/events/components/sections/EditTickets.vue.js +1 -1
  63. package/dist/martyrs/src/modules/gallery/components/sections/BackofficeGallery.vue.js +4 -4
  64. package/dist/martyrs/src/modules/gallery/components/sections/BackofficeGallery.vue.js.map +1 -1
  65. package/dist/martyrs/src/modules/inventory/components/forms/AdjustmentForm.vue.js +2 -2
  66. package/dist/martyrs/src/modules/inventory/components/forms/ColumnSettingsMenu.vue.js +1 -1
  67. package/dist/martyrs/src/modules/inventory/components/forms/HistoryView.vue.js +1 -1
  68. package/dist/martyrs/src/modules/inventory/components/forms/StockAlertsForm.vue.js +2 -2
  69. package/dist/martyrs/src/modules/inventory/components/pages/Inventory.vue.js +4 -4
  70. package/dist/martyrs/src/modules/inventory/components/pages/Inventory.vue.js.map +1 -1
  71. package/dist/martyrs/src/modules/inventory/components/pages/InventoryEdit.vue.js +2 -2
  72. package/dist/martyrs/src/modules/inventory/components/pages/InventoryEdit.vue.js.map +1 -1
  73. package/dist/martyrs/src/modules/landing/components/sections/SectionGuide.vue.js +1 -1
  74. package/dist/martyrs/src/modules/marketplace/views/components/pages/Marketplace.vue.js +1 -1
  75. package/dist/martyrs/src/modules/music/components/blocks/ActionButtons.vue.js +1 -1
  76. package/dist/martyrs/src/modules/music/components/cards/AlbumCard.vue.js +1 -1
  77. package/dist/martyrs/src/modules/music/components/cards/ArtistCardSmall.vue.js +1 -1
  78. package/dist/martyrs/src/modules/music/components/cards/PlaylistCard.vue.js +1 -1
  79. package/dist/martyrs/src/modules/music/components/cards/TrackListCard.vue.js +1 -1
  80. package/dist/martyrs/src/modules/music/components/forms/AlbumForm.vue.js +2 -2
  81. package/dist/martyrs/src/modules/music/components/forms/ArtistForm.vue.js +2 -2
  82. package/dist/martyrs/src/modules/music/components/forms/PlaylistForm.vue.js +1 -1
  83. package/dist/martyrs/src/modules/music/components/forms/SearchForm.vue.js +1 -1
  84. package/dist/martyrs/src/modules/music/components/forms/TrackForm.vue.js +2 -2
  85. package/dist/martyrs/src/modules/music/components/pages/Album.vue.js +1 -1
  86. package/dist/martyrs/src/modules/music/components/pages/Artist.vue.js +1 -1
  87. package/dist/martyrs/src/modules/music/components/pages/MusicLibrary.vue.js +1 -1
  88. package/dist/martyrs/src/modules/music/components/pages/Playlist.vue.js +6 -6
  89. package/dist/martyrs/src/modules/music/components/pages/Playlist.vue.js.map +1 -1
  90. package/dist/martyrs/src/modules/music/components/pages/SearchResults.vue.js +1 -1
  91. package/dist/martyrs/src/modules/music/components/pages/Track.vue.js +1 -1
  92. package/dist/martyrs/src/modules/music/components/pages/TrackCreate.vue.js +1 -1
  93. package/dist/martyrs/src/modules/music/components/player/FullscreenPlayer.vue.js +1 -1
  94. package/dist/martyrs/src/modules/music/components/player/MusicPlayer.vue.js +1 -1
  95. package/dist/martyrs/src/modules/music/components/player/PlayerControls.vue.js +1 -1
  96. package/dist/martyrs/src/modules/music/components/player/VolumeControl.vue.js +1 -1
  97. package/dist/martyrs/src/modules/notifications/components/elements/NotificationBadge.vue.js +3 -3
  98. package/dist/martyrs/src/modules/notifications/components/elements/NotificationBadge.vue.js.map +1 -1
  99. package/dist/martyrs/src/modules/notifications/components/sections/NotificationPreferences.vue.js +1 -1
  100. package/dist/martyrs/src/modules/orders/components/blocks/CardOrderUser.vue.js +90 -175
  101. package/dist/martyrs/src/modules/orders/components/blocks/CardOrderUser.vue.js.map +1 -1
  102. package/dist/martyrs/src/modules/orders/components/forms/FormApplicationDetails.vue.js +2 -2
  103. package/dist/martyrs/src/modules/orders/components/forms/FormCustomerDetails.vue.js +2 -2
  104. package/dist/martyrs/src/modules/orders/components/forms/FormSelectCustomer.vue.js +1 -1
  105. package/dist/martyrs/src/modules/orders/components/pages/OrderBackoffice.vue.js +8 -8
  106. package/dist/martyrs/src/modules/orders/components/pages/OrderBackoffice.vue.js.map +1 -1
  107. package/dist/martyrs/src/modules/orders/components/pages/OrderCreate.vue.js +1 -1
  108. package/dist/martyrs/src/modules/orders/components/pages/OrderCreateBackoffice.vue.js +1 -1
  109. package/dist/martyrs/src/modules/orders/components/pages/Orders.vue.js +41 -28
  110. package/dist/martyrs/src/modules/orders/components/pages/Orders.vue.js.map +1 -1
  111. package/dist/martyrs/src/modules/orders/components/sections/ApplicationDetails.vue.js +1 -1
  112. package/dist/martyrs/src/modules/orders/components/sections/CustomerDetails.vue.js +1 -1
  113. package/dist/martyrs/src/modules/orders/components/sections/FormDelivery.vue.js +1 -1
  114. package/dist/martyrs/src/modules/orders/components/sections/FormPayment.vue.js +1 -1
  115. package/dist/martyrs/src/modules/orders/orders.client.js +14 -14
  116. package/dist/martyrs/src/modules/orders/orders.client.js.map +1 -1
  117. package/dist/martyrs/src/modules/orders/router/orders.router.js +23 -0
  118. package/dist/martyrs/src/modules/orders/router/orders.router.js.map +1 -1
  119. package/dist/martyrs/src/modules/organizations/components/blocks/CardDepartment.vue.js +1 -1
  120. package/dist/martyrs/src/modules/organizations/components/blocks/CardOrganization.vue.js +1 -1
  121. package/dist/martyrs/src/modules/organizations/components/blocks/CardOrganization.vue.js.map +1 -1
  122. package/dist/martyrs/src/modules/organizations/components/elements/ButtonToggleMembership.vue.js +1 -1
  123. package/dist/martyrs/src/modules/organizations/components/forms/AddExistingMembersForm.vue.js +1 -1
  124. package/dist/martyrs/src/modules/organizations/components/forms/DepartmentForm.vue.js +2 -2
  125. package/dist/martyrs/src/modules/organizations/components/forms/InviteForm.vue.js +1 -1
  126. package/dist/martyrs/src/modules/organizations/components/pages/Department.vue.js +1 -1
  127. package/dist/martyrs/src/modules/organizations/components/pages/OrganizationEdit.vue.js +89 -40
  128. package/dist/martyrs/src/modules/organizations/components/pages/OrganizationEdit.vue.js.map +1 -1
  129. package/dist/martyrs/src/modules/organizations/components/sections/Documents.vue.js +1 -1
  130. package/dist/martyrs/src/modules/organizations/components/sections/MembersAdd.vue.js +2 -2
  131. package/dist/martyrs/src/modules/organizations/components/sections/Organizations.vue.js +1 -1
  132. package/dist/martyrs/src/modules/pages/views/components/blocks/CardPage.vue.js +1 -1
  133. package/dist/martyrs/src/modules/pages/views/components/pages/PageEdit.vue.js +3 -3
  134. package/dist/martyrs/src/modules/pages/views/components/pages/PageEdit.vue.js.map +1 -1
  135. package/dist/martyrs/src/modules/pages/views/components/partials/SidebarPages.vue.js +2 -2
  136. package/dist/martyrs/src/modules/pages/views/components/partials/SidebarPages.vue.js.map +1 -1
  137. package/dist/martyrs/src/modules/products/components/pages/Categories.vue.js +1 -1
  138. package/dist/martyrs/src/modules/products/components/pages/CategoryEdit.vue.js +3 -3
  139. package/dist/martyrs/src/modules/products/components/pages/Product.vue.js +1 -1
  140. package/dist/martyrs/src/modules/products/components/pages/ProductEdit.vue.js +3 -3
  141. package/dist/martyrs/src/modules/products/components/pages/Products.vue.js +3 -3
  142. package/dist/martyrs/src/modules/products/components/pages/Products.vue.js.map +1 -1
  143. package/dist/martyrs/src/modules/products/components/sections/EditAttributes.vue.js +1 -1
  144. package/dist/martyrs/src/modules/products/components/sections/EditDiscounts.vue.js +3 -3
  145. package/dist/martyrs/src/modules/products/components/sections/EditDiscounts.vue.js.map +1 -1
  146. package/dist/martyrs/src/modules/products/components/sections/EditVariants.vue.js +3 -3
  147. package/dist/martyrs/src/modules/products/components/sections/FilterProducts.vue.js +1 -1
  148. package/dist/martyrs/src/modules/products/components/sections/ProductConfigurator.vue.js +2 -2
  149. package/dist/martyrs/src/modules/products/components/sections/ProductConfigurator.vue.js.map +1 -1
  150. package/dist/martyrs/src/modules/products/components/sections/ProductsRecommended.vue.js +1 -1
  151. package/dist/martyrs/src/modules/products/components/sections/SectionProduct.vue.js +1 -1
  152. package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttToolbar.vue.js +1 -1
  153. package/dist/martyrs/src/modules/rents/views/components/pages/RentsEdit.vue.js +1 -1
  154. package/dist/martyrs/src/modules/reports/components/sections/FormReport.vue.js +2 -2
  155. package/dist/martyrs/src/modules/spots/components/blocks/SpotMemberModify.vue.js +1 -1
  156. package/dist/martyrs/src/modules/spots/components/layouts/Spots.vue.js +1 -1
  157. package/dist/martyrs/src/modules/spots/components/pages/Map.vue.js +1 -1
  158. package/dist/martyrs/src/modules/spots/components/pages/Spot.vue.js +1 -1
  159. package/dist/martyrs/src/modules/spots/components/pages/SpotEdit.vue.js +2 -2
  160. package/dist/martyrs/src/modules/spots/components/pages/Spots.vue.js +1 -1
  161. package/dist/martyrs/src/modules/spots/components/pages/Spots.vue.js.map +1 -1
  162. package/dist/martyrs/src/modules/spots/components/sections/WorktimeEdit.vue.js +2 -2
  163. package/dist/martyrs/src/modules/wallet/views/components/blocks/CryptoDeposit.vue.js +2 -2
  164. package/dist/martyrs/src/modules/wallet/views/components/blocks/CryptoDeposit.vue.js.map +1 -1
  165. package/dist/martyrs/src/modules/wallet/views/components/pages/Wallet.vue.js +3 -3
  166. package/dist/martyrs/src/modules/wallet/views/components/pages/Wallet.vue.js.map +1 -1
  167. package/dist/martyrs.css +1 -1
  168. package/dist/martyrs.es.js +1 -1
  169. package/dist/style.css +105 -110
  170. package/dist/{web-BNJDRie_.js → web-BDuQSQKS.js} +1 -1
  171. package/package.json +1 -1
  172. package/src/components/Calendar/Calendar.vue +4 -4
  173. package/src/components/Completion/Completion.vue +3 -3
  174. package/src/components/Field/Field.vue +1 -1
  175. package/src/components/FieldBig/FieldBig.vue +1 -1
  176. package/src/components/FieldDate/FieldDate.vue +1 -1
  177. package/src/modules/TASKS.MD +26 -1
  178. package/src/modules/auth/views/components/pages/Profile.vue +9 -15
  179. package/src/modules/auth/views/components/pages/UserDashboard.vue +214 -125
  180. package/src/modules/auth/views/configs/navigation.user.config.js +8 -2
  181. package/src/modules/community/components/layouts/Community.vue +2 -2
  182. package/src/modules/core/views/components/blocks/CardHeader.vue +1 -1
  183. package/src/modules/core/views/components/partials/Header.vue +1 -1
  184. package/src/modules/core/views/components/partials/Sidebar.vue +1 -1
  185. package/src/modules/core/views/components/sections/Filters.vue +2 -2
  186. package/src/modules/core/views/components/sections/SectionPageTitle.vue +1 -1
  187. package/src/modules/events/components/pages/EditEventTickets.vue +2 -2
  188. package/src/modules/gallery/components/sections/BackofficeGallery.vue +1 -1
  189. package/src/modules/inventory/components/pages/Inventory.vue +4 -4
  190. package/src/modules/inventory/components/pages/InventoryEdit.vue +1 -1
  191. package/src/modules/music/components/pages/Playlist.vue +5 -5
  192. package/src/modules/notifications/components/elements/NotificationBadge.vue +1 -1
  193. package/src/modules/orders/components/blocks/CardOrderUser.vue +88 -190
  194. package/src/modules/orders/components/pages/OrderBackoffice.vue +5 -5
  195. package/src/modules/orders/components/pages/Orders.vue +56 -50
  196. package/src/modules/orders/router/orders.router.js +33 -0
  197. package/src/modules/organizations/components/blocks/CardOrganization.vue +1 -1
  198. package/src/modules/organizations/components/pages/OrganizationEdit.vue +42 -11
  199. package/src/modules/pages/views/components/pages/PageEdit.vue +2 -2
  200. package/src/modules/pages/views/components/partials/SidebarPages.vue +1 -1
  201. package/src/modules/products/components/pages/Products.vue +1 -1
  202. package/src/modules/products/components/sections/EditDiscounts.vue +1 -1
  203. package/src/modules/products/components/sections/ProductConfigurator.vue +1 -1
  204. package/src/modules/spots/components/pages/Spots.vue +1 -1
  205. package/src/modules/wallet/views/components/blocks/CryptoDeposit.vue +1 -1
  206. package/src/modules/wallet/views/components/pages/Wallet.vue +1 -1
  207. package/dist/martyrs/dist/main-vq1_XpmQ.js.map +0 -1
  208. package/dist/martyrs/src/components/Button/Button.vue.js.map +0 -1
  209. package/dist/martyrs/src/components/EditImages/EditImages.vue.js.map +0 -1
  210. package/dist/martyrs/src/components/Select/Select.vue2.js.map +0 -1
  211. package/dist/martyrs/src/components/SelectMulti/SelectMulti.vue2.js +0 -625
  212. package/dist/martyrs/src/components/SelectMulti/SelectMulti.vue2.js.map +0 -1
  213. package/dist/martyrs/src/components/Spoiler/Spoiler.vue.js.map +0 -1
  214. package/dist/martyrs/src/modules/core/views/components/sections/Filters.vue.js.map +0 -1
  215. package/dist/martyrs/src/modules/orders/components/icons/IconStatusCanceled.vue.js +0 -32
  216. package/dist/martyrs/src/modules/orders/components/icons/IconStatusCanceled.vue.js.map +0 -1
  217. package/dist/martyrs/src/modules/orders/components/icons/IconStatusConfirmed.vue.js +0 -32
  218. package/dist/martyrs/src/modules/orders/components/icons/IconStatusConfirmed.vue.js.map +0 -1
  219. package/dist/martyrs/src/modules/orders/components/icons/IconStatusCreated.vue.js +0 -32
  220. package/dist/martyrs/src/modules/orders/components/icons/IconStatusCreated.vue.js.map +0 -1
  221. package/dist/martyrs/src/modules/orders/components/icons/IconStatusDelay.vue.js +0 -32
  222. package/dist/martyrs/src/modules/orders/components/icons/IconStatusDelay.vue.js.map +0 -1
  223. package/dist/martyrs/src/modules/orders/components/icons/IconStatusFinished.vue.js +0 -32
  224. package/dist/martyrs/src/modules/orders/components/icons/IconStatusFinished.vue.js.map +0 -1
  225. package/dist/martyrs/src/modules/orders/components/icons/IconStatusInUse.vue.js +0 -32
  226. package/dist/martyrs/src/modules/orders/components/icons/IconStatusInUse.vue.js.map +0 -1
@@ -1,15 +1,14 @@
1
- import { ref, computed, onMounted, resolveComponent, createElementBlock, openBlock, createBlock, createCommentVNode, createVNode, unref, withCtx, createElementVNode, toDisplayString, Fragment, renderList } from "vue";
2
- import { useRoute, useRouter } from "vue-router";
3
- import { useGlobalMixins } from "../../../core/views/mixins/mixins.js";
4
- /* empty css */
1
+ import { ref, computed, resolveComponent, createElementBlock, openBlock, createBlock, createCommentVNode, createVNode, unref, withCtx, createElementVNode, toDisplayString, normalizeClass, Fragment, renderList } from "vue";
2
+ import { useRoute } from "vue-router";
3
+ import _sfc_main$3 from "../../../../components/Tab/Tab.vue.js";
5
4
  import _sfc_main$2 from "../../../../components/Block/Block.vue.js";
5
+ import _sfc_main$4 from "../../../../components/Feed/Feed.vue.js";
6
6
  import { state, actions, getters } from "../../store/orders.js";
7
7
  import { state as state$1 } from "../../../auth/views/store/auth.js";
8
- /* empty css */
9
- import CardOrderUser from "../blocks/CardOrderUser.vue.js";
10
- import _sfc_main$4 from "../blocks/CardOrderBackoffice.vue.js";
8
+ import _sfc_main$6 from "../blocks/CardOrderUser.vue.js";
9
+ import _sfc_main$5 from "../blocks/CardOrderBackoffice.vue.js";
11
10
  import _sfc_main$1 from "../../../core/views/components/sections/SectionPageTitle.vue.js";
12
- import _sfc_main$3 from "../../../../components/Feed/Feed.vue.js";
11
+ import { useGlobalMixins } from "../../../core/views/mixins/mixins.js";
13
12
  const _hoisted_1 = { class: "mobile:pd-thin pd-medium" };
14
13
  const _hoisted_2 = { class: "gap-micro flex-nowrap flex" };
15
14
  const _hoisted_3 = { class: "w-100 bg-white radius-small pd-small" };
@@ -19,10 +18,23 @@ const _sfc_main = {
19
18
  __name: "Orders",
20
19
  setup(__props) {
21
20
  const route = useRoute();
22
- useRouter();
23
21
  const { returnCurrency, formatPrice, formatDate } = useGlobalMixins();
24
- ref(false);
25
22
  const tab = ref("all");
23
+ const tabs = [
24
+ { label: "All Orders", value: "all" },
25
+ { label: "In Progress", value: "in_progress" },
26
+ { label: "Returns & Cancellations", value: "returns" }
27
+ ];
28
+ const tabStatusFilter = computed(() => {
29
+ switch (tab.value) {
30
+ case "in_progress":
31
+ return ["created", "confirmed", "processing", "preparing", "shipped"];
32
+ case "returns":
33
+ return ["cancelled", "canceled", "returned"];
34
+ default:
35
+ return null;
36
+ }
37
+ });
26
38
  const totalPrice = computed(() => {
27
39
  return calculateTotalSum(state.all);
28
40
  });
@@ -36,14 +48,12 @@ const _sfc_main = {
36
48
  }
37
49
  function calculateSum(orders, status) {
38
50
  return orders.reduce((totalSum, item) => {
39
- if (item.payment.status === status) {
51
+ if (item.payment?.status === status) {
40
52
  return totalSum + item.positions.reduce((sum, position) => sum + position.price, 0);
41
53
  }
42
54
  return totalSum;
43
55
  }, 0);
44
56
  }
45
- onMounted(async () => {
46
- });
47
57
  return (_ctx, _cache) => {
48
58
  const _component_router_link = resolveComponent("router-link");
49
59
  return openBlock(), createElementBlock("div", _hoisted_1, [
@@ -64,22 +74,30 @@ const _sfc_main = {
64
74
  default: withCtx(() => [
65
75
  createElementVNode("div", _hoisted_2, [
66
76
  createElementVNode("div", _hoisted_3, [
67
- _cache[0] || (_cache[0] = createElementVNode("p", { class: "mn-b-thin" }, "Total", -1)),
77
+ _cache[1] || (_cache[1] = createElementVNode("p", { class: "mn-b-thin" }, "Total", -1)),
68
78
  createElementVNode("h3", null, toDisplayString(unref(formatPrice)(totalPrice.value)), 1)
69
79
  ]),
70
80
  createElementVNode("div", _hoisted_4, [
71
- _cache[1] || (_cache[1] = createElementVNode("p", { class: "mn-b-thin" }, "Paid", -1)),
81
+ _cache[2] || (_cache[2] = createElementVNode("p", { class: "mn-b-thin" }, "Paid", -1)),
72
82
  createElementVNode("h3", null, toDisplayString(unref(formatPrice)(totalPriceUnpaid.value)), 1)
73
83
  ]),
74
84
  createElementVNode("div", _hoisted_5, [
75
- _cache[2] || (_cache[2] = createElementVNode("p", { class: "mn-b-thin" }, "Unpaid", -1)),
85
+ _cache[3] || (_cache[3] = createElementVNode("p", { class: "mn-b-thin" }, "Unpaid", -1)),
76
86
  createElementVNode("h3", null, toDisplayString(unref(formatPrice)(totalPrice.value)), 1)
77
87
  ])
78
88
  ])
79
89
  ]),
80
90
  _: 1
81
91
  })) : createCommentVNode("", true),
82
- createVNode(_sfc_main$3, {
92
+ unref(route).meta.context === "user" ? (openBlock(), createBlock(_sfc_main$3, {
93
+ key: 2,
94
+ tabs,
95
+ selected: tab.value,
96
+ "onUpdate:selected": _cache[0] || (_cache[0] = ($event) => tab.value = $event),
97
+ classTab: "bg-light",
98
+ class: "mn-b-small"
99
+ }, null, 8, ["selected"])) : createCommentVNode("", true),
100
+ createVNode(_sfc_main$4, {
83
101
  search: true,
84
102
  states: {
85
103
  empty: {
@@ -94,9 +112,9 @@ const _sfc_main = {
94
112
  limit: 15,
95
113
  ...unref(route).meta.context === "organization" && { owner: unref(route).params._id },
96
114
  ...unref(route).meta.context === "user" && { customer: unref(route).params._id },
97
- ...tab.value !== "all" && { status: tab.value }
115
+ ...tab.value !== "all" && { status: tabStatusFilter.value }
98
116
  },
99
- class: "gap-thin cols-3 mobile:cols-1"
117
+ class: normalizeClass(unref(route).meta.context === "user" ? "gap-small cols-1" : "gap-thin cols-3 mobile:cols-1")
100
118
  }, {
101
119
  default: withCtx(({
102
120
  items
@@ -109,7 +127,7 @@ const _sfc_main = {
109
127
  }
110
128
  }, {
111
129
  default: withCtx(() => [
112
- createVNode(_sfc_main$4, {
130
+ createVNode(_sfc_main$5, {
113
131
  order,
114
132
  user: state$1.user,
115
133
  formatDate: unref(formatDate),
@@ -122,15 +140,10 @@ const _sfc_main = {
122
140
  }), 256)) : createCommentVNode("", true),
123
141
  unref(route).meta.context === "user" ? (openBlock(true), createElementBlock(Fragment, { key: 1 }, renderList(items, (order) => {
124
142
  return openBlock(), createBlock(_component_router_link, {
125
- to: {
126
- name: "UserOrder",
127
- params: {
128
- order: order._id
129
- }
130
- }
143
+ to: `/users/${unref(route).params._id}/orders/${order._id}`
131
144
  }, {
132
145
  default: withCtx(() => [
133
- createVNode(CardOrderUser, {
146
+ createVNode(_sfc_main$6, {
134
147
  orderId: order._id,
135
148
  status: order.status,
136
149
  createdAt: order.createdAt,
@@ -144,7 +157,7 @@ const _sfc_main = {
144
157
  }), 256)) : createCommentVNode("", true)
145
158
  ]),
146
159
  _: 1
147
- }, 8, ["store", "options"])
160
+ }, 8, ["store", "options", "class"])
148
161
  ]);
149
162
  };
150
163
  }
@@ -1 +1 @@
1
- {"version":3,"file":"Orders.vue.js","sources":["../../../../../../../src/modules/orders/components/pages/Orders.vue"],"sourcesContent":["<template>\n <div class=\"mobile:pd-thin pd-medium\"> \n <SectionPageTitle\n v-if=\"!MOBILE_APP\"\n title=\"Orders\"\n :actions=\"[\n route.meta.context === 'backoffice' && { to: { name: 'BackofficeAdminCreateOrder' }, label: 'Create Order' },\n route.meta.context === 'organization' && { to: { name: 'OrganizationAdminCreateOrder', params: { _id: route.params._id}}, label: 'Create Order' }\n ].filter(Boolean)\"\n class=\"mn-b-small\"\n />\n\n <Block\n v-if=\"route.meta.context !== 'user'\"\n title=\"Balance\"\n class=\"mn-b-small\"\n >\n <div class=\"gap-micro flex-nowrap flex\">\n <div class=\"w-100 bg-white radius-small pd-small\">\n <p class=\"mn-b-thin\">Total</p>\n <h3>{{formatPrice(totalPrice)}}</h3>\n </div>\n <div class=\"w-100 bg-white radius-small pd-small\">\n <p class=\"mn-b-thin\">Paid</p>\n <h3>{{formatPrice(totalPriceUnpaid)}}</h3>\n </div>\n <div class=\"w-100 bg-white radius-small pd-small\">\n <p class=\"mn-b-thin\">Unpaid</p>\n <h3>{{formatPrice(totalPrice)}}</h3>\n </div>\n </div>\n\n </Block>\n\n <Feed\n :search=\"true\"\n :states=\"{\n empty: {\n title: 'No Orders Found',\n description: 'Currently, there are no orders.'\n }\n }\"\n :store=\"{\n read: (options) => orders.actions.read(options)\n }\"\n :options=\"{\n limit: 15,\n ...(route.meta.context === 'organization' && { owner: route.params._id }),\n ...(route.meta.context === 'user' && { customer: route.params._id }),\n ...(tab !== 'all' && { status: tab })\n }\"\n v-slot=\"{ \n items \n }\"\n class=\"gap-thin cols-3 mobile:cols-1\"\n >\n <router-link \n v-if=\"route.meta.context !== 'user'\"\n v-for=\"order in items\" \n :to=\"{ \n name: route.meta.context === 'backoffice' ? 'BackofficeOrderEdit' : 'OrganizationOrderEdit', \n params: route.meta.context === 'backoffice' \n ? { order: order._id } \n : { order: order._id, organization: order.owner.target || order.owner._id }\n }\" \n >\n <CardOrderBackoffice \n :order=\"order\"\n :user=\"auth.state.user\"\n :formatDate=\"formatDate\"\n :getTotal=\"orders.getters.getTotal\"\n :currency=\"returnCurrency()\"\n />\n </router-link>\n\n <router-link \n v-if=\"route.meta.context === 'user'\"\n v-for=\"order in items\" \n :to=\"{ \n name: 'UserOrder', \n params: { \n order: order._id \n }\n }\" \n >\n <CardOrderUser\n :orderId=\"order._id\"\n :status=\"order.status\"\n :createdAt=\"order.createdAt\"\n :updatedAt=\"order.updatedAt\"\n :positions=\"order.positions\"\n :total=\"orders.getters.getTotal(order.positions)\"\n />\n </router-link>\n </Feed>\n </div>\n</template>\n\n<script setup>\n import { computed, onMounted, reactive, ref } from 'vue';\n import { useRoute, useRouter } from 'vue-router';\n\n import Tab from '@martyrs/src/components/Tab/Tab.vue'\n import Block from '@martyrs/src/components/Block/Block.vue';\n\n import * as orders from '@martyrs/src/modules/orders/store/orders.js';\n import * as auth from '@martyrs/src/modules/auth/views/store/auth.js';\n\n import CardOrder from '@martyrs/src/modules/orders/components/blocks/CardOrder.vue'\n\n import CardOrderUser from '@martyrs/src/modules/orders/components/blocks/CardOrderUser.vue'\n import CardOrderBackoffice from '@martyrs/src/modules/orders/components/blocks/CardOrderBackoffice.vue'\n\n import SectionPageTitle from '@martyrs/src/modules/core/views/components/sections/SectionPageTitle.vue'\n\n import Feed from '@martyrs/src/components/Feed/Feed.vue'\n\n import IconTime from '@martyrs/src/modules/icons/entities/IconTime.vue'\n import { useGlobalMixins } from '@martyrs/src/modules/core/views/mixins/mixins.js'\n\n const route = useRoute();\n const router = useRouter();\n const { returnCurrency, formatPrice, formatDate } = useGlobalMixins()\n\n const spoiler = ref(false)\n\n // Tab logic\n const tab = ref('all')\n\n const totalPrice = computed(() => {\n return calculateTotalSum(orders.state.all)\n });\n\n const totalPriceUnpaid = computed(() => {\n return calculateSum(orders.state.all,'unpaid')\n });\n\n \n function calculateTotalSum(orders) {\n return orders.reduce((totalSum, item) => {\n return totalSum + item.positions.reduce((sum, position) => sum + position.price, 0);\n }, 0);\n }\n\n function calculateSum(orders, status) {\n return orders.reduce((totalSum, item) => {\n if (item.payment.status === status) {\n return totalSum + item.positions.reduce((sum, position) => sum + position.price, 0);\n }\n return totalSum;\n }, 0);\n }\n\n\n onMounted(async () => {\n \n });\n</script>\n"],"names":["orders.state"],"mappings":";;;;;;;;;;;;;;;;;;;;AAwHE,UAAM,QAAQ,SAAQ;AACP,cAAS;AACxB,UAAM,EAAE,gBAAgB,aAAa,WAAU,IAAK,gBAAe;AAEnD,QAAI,KAAK;AAGzB,UAAM,MAAM,IAAI,KAAK;AAErB,UAAM,aAAa,SAAS,MAAM;AAChC,aAAO,kBAAkBA,MAAa,GAAG;AAAA,IAC3C,CAAC;AAEA,UAAM,mBAAmB,SAAS,MAAM;AACvC,aAAO,aAAaA,MAAa,KAAI,QAAQ;AAAA,IAC/C,CAAC;AAGD,aAAS,kBAAkB,QAAQ;AACjC,aAAO,OAAO,OAAO,CAAC,UAAU,SAAS;AACvC,eAAO,WAAW,KAAK,UAAU,OAAO,CAAC,KAAK,aAAa,MAAM,SAAS,OAAO,CAAC;AAAA,MACpF,GAAG,CAAC;AAAA,IACN;AAEA,aAAS,aAAa,QAAQ,QAAQ;AACpC,aAAO,OAAO,OAAO,CAAC,UAAU,SAAS;AACvC,YAAI,KAAK,QAAQ,WAAW,QAAQ;AAClC,iBAAO,WAAW,KAAK,UAAU,OAAO,CAAC,KAAK,aAAa,MAAM,SAAS,OAAO,CAAC;AAAA,QACpF;AACA,eAAO;AAAA,MACT,GAAG,CAAC;AAAA,IACN;AAGA,cAAU,YAAY;AAAA,IAEtB,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"Orders.vue.js","sources":["../../../../../../../src/modules/orders/components/pages/Orders.vue"],"sourcesContent":["<template>\n <div class=\"mobile:pd-thin pd-medium\">\n <SectionPageTitle\n v-if=\"!MOBILE_APP\"\n title=\"Orders\"\n :actions=\"[\n route.meta.context === 'backoffice' && { to: { name: 'BackofficeAdminCreateOrder' }, label: 'Create Order' },\n route.meta.context === 'organization' && { to: { name: 'OrganizationAdminCreateOrder', params: { _id: route.params._id}}, label: 'Create Order' }\n ].filter(Boolean)\"\n class=\"mn-b-small\"\n />\n\n <Block\n v-if=\"route.meta.context !== 'user'\"\n title=\"Balance\"\n class=\"mn-b-small\"\n >\n <div class=\"gap-micro flex-nowrap flex\">\n <div class=\"w-100 bg-white radius-small pd-small\">\n <p class=\"mn-b-thin\">Total</p>\n <h3>{{formatPrice(totalPrice)}}</h3>\n </div>\n <div class=\"w-100 bg-white radius-small pd-small\">\n <p class=\"mn-b-thin\">Paid</p>\n <h3>{{formatPrice(totalPriceUnpaid)}}</h3>\n </div>\n <div class=\"w-100 bg-white radius-small pd-small\">\n <p class=\"mn-b-thin\">Unpaid</p>\n <h3>{{formatPrice(totalPrice)}}</h3>\n </div>\n </div>\n </Block>\n\n <!-- Tabs for user context -->\n <Tab\n v-if=\"route.meta.context === 'user'\"\n :tabs=\"tabs\"\n v-model:selected=\"tab\"\n classTab=\"bg-light\"\n class=\"mn-b-small\"\n />\n\n <Feed\n :search=\"true\"\n :states=\"{\n empty: {\n title: 'No Orders Found',\n description: 'Currently, there are no orders.'\n }\n }\"\n :store=\"{\n read: (options) => orders.actions.read(options)\n }\"\n :options=\"{\n limit: 15,\n ...(route.meta.context === 'organization' && { owner: route.params._id }),\n ...(route.meta.context === 'user' && { customer: route.params._id }),\n ...(tab !== 'all' && { status: tabStatusFilter })\n }\"\n v-slot=\"{\n items\n }\"\n :class=\"route.meta.context === 'user' ? 'gap-small cols-1' : 'gap-thin cols-3 mobile:cols-1'\"\n >\n <router-link\n v-if=\"route.meta.context !== 'user'\"\n v-for=\"order in items\"\n :to=\"{\n name: route.meta.context === 'backoffice' ? 'BackofficeOrderEdit' : 'OrganizationOrderEdit',\n params: route.meta.context === 'backoffice'\n ? { order: order._id }\n : { order: order._id, organization: order.owner.target || order.owner._id }\n }\"\n >\n <CardOrderBackoffice\n :order=\"order\"\n :user=\"auth.state.user\"\n :formatDate=\"formatDate\"\n :getTotal=\"orders.getters.getTotal\"\n :currency=\"returnCurrency()\"\n />\n </router-link>\n\n <router-link\n v-if=\"route.meta.context === 'user'\"\n v-for=\"order in items\"\n :to=\"`/users/${route.params._id}/orders/${order._id}`\"\n >\n <CardOrderUser\n :orderId=\"order._id\"\n :status=\"order.status\"\n :createdAt=\"order.createdAt\"\n :updatedAt=\"order.updatedAt\"\n :positions=\"order.positions\"\n :total=\"orders.getters.getTotal(order.positions)\"\n />\n </router-link>\n </Feed>\n </div>\n</template>\n\n<script setup>\n import { computed, ref } from 'vue';\n import { useRoute } from 'vue-router';\n\n import Tab from '@martyrs/src/components/Tab/Tab.vue'\n import Block from '@martyrs/src/components/Block/Block.vue';\n import Feed from '@martyrs/src/components/Feed/Feed.vue'\n\n import * as orders from '@martyrs/src/modules/orders/store/orders.js';\n import * as auth from '@martyrs/src/modules/auth/views/store/auth.js';\n\n import CardOrderUser from '@martyrs/src/modules/orders/components/blocks/CardOrderUser.vue'\n import CardOrderBackoffice from '@martyrs/src/modules/orders/components/blocks/CardOrderBackoffice.vue'\n import SectionPageTitle from '@martyrs/src/modules/core/views/components/sections/SectionPageTitle.vue'\n\n import { useGlobalMixins } from '@martyrs/src/modules/core/views/mixins/mixins.js'\n\n const route = useRoute();\n const { returnCurrency, formatPrice, formatDate } = useGlobalMixins()\n\n // Tab logic\n const tab = ref('all')\n\n const tabs = [\n { label: 'All Orders', value: 'all' },\n { label: 'In Progress', value: 'in_progress' },\n { label: 'Returns & Cancellations', value: 'returns' }\n ]\n\n const tabStatusFilter = computed(() => {\n switch (tab.value) {\n case 'in_progress':\n return ['created', 'confirmed', 'processing', 'preparing', 'shipped']\n case 'returns':\n return ['cancelled', 'canceled', 'returned']\n default:\n return null\n }\n })\n\n const totalPrice = computed(() => {\n return calculateTotalSum(orders.state.all)\n });\n\n const totalPriceUnpaid = computed(() => {\n return calculateSum(orders.state.all,'unpaid')\n });\n\n function calculateTotalSum(orders) {\n return orders.reduce((totalSum, item) => {\n return totalSum + item.positions.reduce((sum, position) => sum + position.price, 0);\n }, 0);\n }\n\n function calculateSum(orders, status) {\n return orders.reduce((totalSum, item) => {\n if (item.payment?.status === status) {\n return totalSum + item.positions.reduce((sum, position) => sum + position.price, 0);\n }\n return totalSum;\n }, 0);\n }\n</script>\n"],"names":["orders.state"],"mappings":";;;;;;;;;;;;;;;;;;;AAsHE,UAAM,QAAQ,SAAQ;AACtB,UAAM,EAAE,gBAAgB,aAAa,WAAU,IAAK,gBAAe;AAGnE,UAAM,MAAM,IAAI,KAAK;AAErB,UAAM,OAAO;AAAA,MACX,EAAE,OAAO,cAAc,OAAO,MAAK;AAAA,MACnC,EAAE,OAAO,eAAe,OAAO,cAAa;AAAA,MAC5C,EAAE,OAAO,2BAA2B,OAAO,UAAS;AAAA,IACxD;AAEE,UAAM,kBAAkB,SAAS,MAAM;AACrC,cAAQ,IAAI,OAAK;AAAA,QACf,KAAK;AACH,iBAAO,CAAC,WAAW,aAAa,cAAc,aAAa,SAAS;AAAA,QACtE,KAAK;AACH,iBAAO,CAAC,aAAa,YAAY,UAAU;AAAA,QAC7C;AACE,iBAAO;AAAA,MACf;AAAA,IACE,CAAC;AAED,UAAM,aAAa,SAAS,MAAM;AAChC,aAAO,kBAAkBA,MAAa,GAAG;AAAA,IAC3C,CAAC;AAED,UAAM,mBAAmB,SAAS,MAAM;AACtC,aAAO,aAAaA,MAAa,KAAI,QAAQ;AAAA,IAC/C,CAAC;AAED,aAAS,kBAAkB,QAAQ;AACjC,aAAO,OAAO,OAAO,CAAC,UAAU,SAAS;AACvC,eAAO,WAAW,KAAK,UAAU,OAAO,CAAC,KAAK,aAAa,MAAM,SAAS,OAAO,CAAC;AAAA,MACpF,GAAG,CAAC;AAAA,IACN;AAEA,aAAS,aAAa,QAAQ,QAAQ;AACpC,aAAO,OAAO,OAAO,CAAC,UAAU,SAAS;AACvC,YAAI,KAAK,SAAS,WAAW,QAAQ;AACnC,iBAAO,WAAW,KAAK,UAAU,OAAO,CAAC,KAAK,aAAa,MAAM,SAAS,OAAO,CAAC;AAAA,QACpF;AACA,eAAO;AAAA,MACT,GAAG,CAAC;AAAA,IACN;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -1,7 +1,7 @@
1
1
  import { createElementBlock, openBlock, createVNode, createElementVNode, withCtx, toDisplayString, createCommentVNode, unref, createTextVNode } from "vue";
2
2
  import _sfc_main$1 from "../../../../components/Block/Block.vue.js";
3
3
  import StatusBadge from "../../../../components/Table/StatusBadge.vue.js";
4
- import _sfc_main$2 from "../../../../components/Button/Button.vue.js";
4
+ import _sfc_main$2 from "../../../../components/Button/Button.vue2.js";
5
5
  import { useGlobalMixins } from "../../../core/views/mixins/mixins.js";
6
6
  /* empty css */
7
7
  import _export_sfc from "../../../../../../_virtual/_plugin-vue_export-helper.js";
@@ -1,7 +1,7 @@
1
1
  import { createElementBlock, openBlock, createVNode, createElementVNode, withCtx, toDisplayString, createCommentVNode, unref, Fragment, renderList, createTextVNode } from "vue";
2
2
  import _sfc_main$1 from "../../../../components/Block/Block.vue.js";
3
3
  import StatusBadge from "../../../../components/Table/StatusBadge.vue.js";
4
- import _sfc_main$2 from "../../../../components/Button/Button.vue.js";
4
+ import _sfc_main$2 from "../../../../components/Button/Button.vue2.js";
5
5
  import { useGlobalMixins } from "../../../core/views/mixins/mixins.js";
6
6
  /* empty css */
7
7
  import _export_sfc from "../../../../../../_virtual/_plugin-vue_export-helper.js";
@@ -10,7 +10,7 @@ import _sfc_main$2 from "../../../../components/Radio/Radio.vue.js";
10
10
  /* empty css */
11
11
  /* empty css */
12
12
  /* empty css */
13
- /* empty css */
13
+ /* empty css */
14
14
  /* empty css */
15
15
  import CardSpot from "../../../spots/components/blocks/CardSpot.vue.js";
16
16
  import { useStore } from "../../../core/views/store/core.store.js";
@@ -1,6 +1,6 @@
1
1
  import { computed, createBlock, openBlock, withCtx, createElementVNode, createVNode } from "vue";
2
2
  import _sfc_main$1 from "../../../../components/Block/Block.vue.js";
3
- import Select from "../../../../components/Select/Select.vue2.js";
3
+ import Select from "../../../../components/Select/Select.vue.js";
4
4
  const _hoisted_1 = { class: "mn-b-small flex-nowrap flex" };
5
5
  const _sfc_main = {
6
6
  __name: "FormPayment",
@@ -8,14 +8,14 @@ import addRoutes from "../core/views/router/addRoutes.js";
8
8
  import ordersRoutes from "./router/orders.router.js";
9
9
  import customersRoutes from "./router/customers.router.js";
10
10
  import applicationsRoutes from "./router/applications.router.js";
11
- import _sfc_main$a from "./components/pages/OrderCreate.vue.js";
12
- import _sfc_main$9 from "./components/pages/OrderCreateBackoffice.vue.js";
13
- import _sfc_main$d from "./components/pages/Orders.vue.js";
14
- import _sfc_main$c from "./components/pages/Customers.vue.js";
15
- import _sfc_main$b from "./components/pages/Applications.vue.js";
11
+ import _sfc_main$b from "./components/pages/OrderCreate.vue.js";
12
+ import _sfc_main$a from "./components/pages/OrderCreateBackoffice.vue.js";
13
+ import _sfc_main$e from "./components/pages/Orders.vue.js";
14
+ import _sfc_main$d from "./components/pages/Customers.vue.js";
15
+ import _sfc_main$c from "./components/pages/Applications.vue.js";
16
16
  import CardOrder from "./components/blocks/CardOrder.vue.js";
17
- import _sfc_main$8 from "./components/blocks/CardOrderItem.vue.js";
18
- import CardOrderUser from "./components/blocks/CardOrderUser.vue.js";
17
+ import _sfc_main$9 from "./components/blocks/CardOrderItem.vue.js";
18
+ import _sfc_main$8 from "./components/blocks/CardOrderUser.vue.js";
19
19
  import CardCustomer from "./components/blocks/CardCustomer.vue.js";
20
20
  import _sfc_main$7 from "./components/blocks/StatusHistory.vue.js";
21
21
  import _sfc_main$5 from "./components/sections/AskToLogin.vue.js";
@@ -173,17 +173,17 @@ const ModuleOrder = {
173
173
  },
174
174
  components: {
175
175
  // Pages
176
- Orders: _sfc_main$d,
177
- Customers: _sfc_main$c,
178
- Applications: _sfc_main$b,
176
+ Orders: _sfc_main$e,
177
+ Customers: _sfc_main$d,
178
+ Applications: _sfc_main$c,
179
179
  // Order,
180
- OrderCreate: _sfc_main$a,
181
- OrderCreateBackoffice: _sfc_main$9,
180
+ OrderCreate: _sfc_main$b,
181
+ OrderCreateBackoffice: _sfc_main$a,
182
182
  // Favorites,
183
183
  // Blocks
184
- CardOrderItem: _sfc_main$8,
184
+ CardOrderItem: _sfc_main$9,
185
185
  CardOrder,
186
- CardOrderUser,
186
+ CardOrderUser: _sfc_main$8,
187
187
  CardCustomer,
188
188
  StatusHistory: _sfc_main$7,
189
189
  // Sections
@@ -1 +1 @@
1
- {"version":3,"file":"orders.client.js","sources":["../../../../../src/modules/orders/orders.client.js"],"sourcesContent":["// Store\nimport * as storeOrders from './store/orders.js';\nimport * as storeShopcart from './store/shopcart.js';\nimport * as storeTestimonials from './store/testimonials.js';\nimport storeCustomers from './store/customers.store.js';\nimport storeApplications from './store/applications.js';\n// Router\nimport addRoutes from '@martyrs/src/modules/core/views/router/addRoutes.js';\nimport routerOrders from './router/orders.router.js';\nimport routerCustomers from './router/customers.router.js';\nimport routerApplications from './router/applications.router.js';\n// Views\nimport OrderCreate from './components/pages/OrderCreate.vue';\nimport OrderCreateBackoffice from './components/pages/OrderCreateBackoffice.vue';\nimport Orders from './components/pages/Orders.vue';\nimport Customers from './components/pages/Customers.vue';\nimport Applications from './components/pages/Applications.vue';\n// import Favorites from './components/pages/Favorites.vue';\n// Importing blocks components\nimport CardOrder from './components/blocks/CardOrder.vue';\nimport CardOrderItem from './components/blocks/CardOrderItem.vue';\nimport CardOrderUser from './components/blocks/CardOrderUser.vue';\nimport CardCustomer from './components/blocks/CardCustomer.vue';\nimport StatusHistory from './components/blocks/StatusHistory.vue';\n// Importing sections components\nimport AskToLogin from './components/sections/AskToLogin.vue';\nimport EmptyState from './components/sections/EmptyState.vue';\nimport FormCustomerDetails from './components/forms/FormCustomerDetails.vue';\nimport FormDelivery from './components/sections/FormDelivery.vue';\nimport FormPayment from './components/sections/FormPayment.vue';\nimport Succes from './components/sections/Succes.vue';\n// Importing partials components\nimport ShopCart from './components/partials/ShopCart.vue';\n\nimport { i18nManager } from '@martyrs/src/modules/core/views/classes/i18n.manager.js';\nimport locales from './locales/index.js';\n\n// Пример функции инициализации для модуля заказов\nfunction initializeOrders(app, store, router, options = {}) {\n // Регистрируем локализацию для модуля orders\n i18nManager.register('orders', locales);\n const route = options.route || 'Home';\n const routeBackoffice = options.routeBackoffice || 'Backoffice Root';\n const routeOrganizations = options.routeOrganizations || 'OrganizationRoot';\n const routeUsers = options.routeUsers || 'User Profile Root';\n\n if (typeof window !== 'undefined') storeShopcart.actions.setShopcart()\n\n addRoutes(router, {\n parentName: route,\n basePath: 'orders',\n routes: routerOrders,\n routeNamePrefix: '',\n filterConfig: {\n include: ['CreateOrder', 'Order'], // Только создание заказа на корневом уровне\n },\n meta: {\n context: 'root',\n },\n });\n\n // Backoffice routes\n if (!options.withBackoffice) {\n addRoutes(router, {\n parentName: routeBackoffice,\n basePath: 'orders', // Промежуточный маршрут /backoffice/orders\n routes: routerOrders,\n routeNamePrefix: 'Backoffice',\n filterConfig: {\n include: ['OrdersList', 'AdminCreateOrder', 'Order', 'OrderEdit'], // Специфичные для бэкофиса маршруты\n },\n meta: {\n context: 'backoffice',\n },\n });\n }\n\n // User routes\n if (!options.withUserRoutes) {\n addRoutes(router, {\n parentName: routeUsers,\n basePath: 'orders', // Промежуточный маршрут /user/orders\n routes: routerOrders,\n routeNamePrefix: 'User',\n filterConfig: {\n include: ['OrdersList', 'Order'], // Специфичные для пользователя маршруты\n },\n meta: {\n context: 'user',\n },\n });\n }\n\n // Organization routes\n if (!options.withOrganizationRoutes) {\n addRoutes(router, {\n parentName: routeOrganizations,\n basePath: 'orders', // Промежуточный маршрут /organization/orders\n routes: routerOrders,\n routeNamePrefix: 'Organization',\n filterConfig: {\n include: ['OrdersList', 'Order', 'AdminCreateOrder', 'OrderEdit'], // Специфичные для организации маршруты\n },\n meta: {\n context: 'organization',\n },\n });\n }\n\n // Customer routes for backoffice\n if (!options.withBackoffice) {\n addRoutes(router, {\n parentName: routeBackoffice,\n basePath: 'customers',\n routes: routerCustomers,\n routeNamePrefix: 'Backoffice',\n filterConfig: {\n include: ['Customers'],\n },\n meta: {\n context: 'backoffice',\n },\n });\n }\n\n // Customer routes for organizations\n if (!options.withOrganizationRoutes) {\n addRoutes(router, {\n parentName: routeOrganizations,\n basePath: 'customers',\n routes: routerCustomers,\n routeNamePrefix: 'Organization',\n filterConfig: {\n include: ['Customers'],\n },\n meta: {\n context: 'organization',\n },\n });\n }\n\n // Application routes for backoffice\n if (!options.withBackoffice) {\n addRoutes(router, {\n parentName: routeBackoffice,\n basePath: 'applications',\n routes: routerApplications,\n routeNamePrefix: 'Backoffice',\n filterConfig: {\n include: ['Applications'],\n },\n meta: {\n context: 'backoffice',\n },\n });\n }\n\n // Application routes for organizations\n if (!options.withOrganizationRoutes) {\n addRoutes(router, {\n parentName: routeOrganizations,\n basePath: 'applications',\n routes: routerApplications,\n routeNamePrefix: 'Organization',\n filterConfig: {\n include: ['Applications'],\n },\n meta: {\n context: 'organization',\n },\n });\n }\n\n store.addStore('orders', storeOrders);\n store.addStore('shopcart', storeShopcart);\n store.addStore('testimonials', storeTestimonials);\n store.addStore('customers', storeCustomers);\n store.addStore('applications', storeApplications);\n}\n\nconst ModuleOrder = {\n initialize: initializeOrders,\n store: {\n storeOrders,\n storeShopcart,\n storeTestimonials,\n storeCustomers,\n storeApplications,\n },\n router: {\n routerOrders,\n routerCustomers,\n routerApplications,\n },\n components: {\n // Pages\n Orders,\n Customers,\n Applications,\n // Order,\n OrderCreate,\n OrderCreateBackoffice,\n // Favorites,\n // Blocks\n CardOrderItem,\n CardOrder,\n CardOrderUser,\n CardCustomer,\n StatusHistory,\n // Sections\n FormCustomerDetails,\n AskToLogin,\n FormDelivery,\n EmptyState,\n Succes,\n FormPayment,\n // Partials\n ShopCart,\n },\n};\n\nexport default ModuleOrder;\n"],"names":["storeShopcart.actions","routerOrders","routerCustomers","routerApplications","storeOrders","storeShopcart","storeTestimonials","storeCustomers","storeApplications","Orders","Customers","Applications","OrderCreate","OrderCreateBackoffice","CardOrderItem","StatusHistory","FormCustomerDetails","AskToLogin","FormDelivery","EmptyState","Succes","FormPayment","ShopCart"],"mappings":"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"}
1
+ {"version":3,"file":"orders.client.js","sources":["../../../../../src/modules/orders/orders.client.js"],"sourcesContent":["// Store\nimport * as storeOrders from './store/orders.js';\nimport * as storeShopcart from './store/shopcart.js';\nimport * as storeTestimonials from './store/testimonials.js';\nimport storeCustomers from './store/customers.store.js';\nimport storeApplications from './store/applications.js';\n// Router\nimport addRoutes from '@martyrs/src/modules/core/views/router/addRoutes.js';\nimport routerOrders from './router/orders.router.js';\nimport routerCustomers from './router/customers.router.js';\nimport routerApplications from './router/applications.router.js';\n// Views\nimport OrderCreate from './components/pages/OrderCreate.vue';\nimport OrderCreateBackoffice from './components/pages/OrderCreateBackoffice.vue';\nimport Orders from './components/pages/Orders.vue';\nimport Customers from './components/pages/Customers.vue';\nimport Applications from './components/pages/Applications.vue';\n// import Favorites from './components/pages/Favorites.vue';\n// Importing blocks components\nimport CardOrder from './components/blocks/CardOrder.vue';\nimport CardOrderItem from './components/blocks/CardOrderItem.vue';\nimport CardOrderUser from './components/blocks/CardOrderUser.vue';\nimport CardCustomer from './components/blocks/CardCustomer.vue';\nimport StatusHistory from './components/blocks/StatusHistory.vue';\n// Importing sections components\nimport AskToLogin from './components/sections/AskToLogin.vue';\nimport EmptyState from './components/sections/EmptyState.vue';\nimport FormCustomerDetails from './components/forms/FormCustomerDetails.vue';\nimport FormDelivery from './components/sections/FormDelivery.vue';\nimport FormPayment from './components/sections/FormPayment.vue';\nimport Succes from './components/sections/Succes.vue';\n// Importing partials components\nimport ShopCart from './components/partials/ShopCart.vue';\n\nimport { i18nManager } from '@martyrs/src/modules/core/views/classes/i18n.manager.js';\nimport locales from './locales/index.js';\n\n// Пример функции инициализации для модуля заказов\nfunction initializeOrders(app, store, router, options = {}) {\n // Регистрируем локализацию для модуля orders\n i18nManager.register('orders', locales);\n const route = options.route || 'Home';\n const routeBackoffice = options.routeBackoffice || 'Backoffice Root';\n const routeOrganizations = options.routeOrganizations || 'OrganizationRoot';\n const routeUsers = options.routeUsers || 'User Profile Root';\n\n if (typeof window !== 'undefined') storeShopcart.actions.setShopcart()\n\n addRoutes(router, {\n parentName: route,\n basePath: 'orders',\n routes: routerOrders,\n routeNamePrefix: '',\n filterConfig: {\n include: ['CreateOrder', 'Order'], // Только создание заказа на корневом уровне\n },\n meta: {\n context: 'root',\n },\n });\n\n // Backoffice routes\n if (!options.withBackoffice) {\n addRoutes(router, {\n parentName: routeBackoffice,\n basePath: 'orders', // Промежуточный маршрут /backoffice/orders\n routes: routerOrders,\n routeNamePrefix: 'Backoffice',\n filterConfig: {\n include: ['OrdersList', 'AdminCreateOrder', 'Order', 'OrderEdit'], // Специфичные для бэкофиса маршруты\n },\n meta: {\n context: 'backoffice',\n },\n });\n }\n\n // User routes\n if (!options.withUserRoutes) {\n addRoutes(router, {\n parentName: routeUsers,\n basePath: 'orders', // Промежуточный маршрут /user/orders\n routes: routerOrders,\n routeNamePrefix: 'User',\n filterConfig: {\n include: ['OrdersList', 'Order'], // Специфичные для пользователя маршруты\n },\n meta: {\n context: 'user',\n },\n });\n }\n\n // Organization routes\n if (!options.withOrganizationRoutes) {\n addRoutes(router, {\n parentName: routeOrganizations,\n basePath: 'orders', // Промежуточный маршрут /organization/orders\n routes: routerOrders,\n routeNamePrefix: 'Organization',\n filterConfig: {\n include: ['OrdersList', 'Order', 'AdminCreateOrder', 'OrderEdit'], // Специфичные для организации маршруты\n },\n meta: {\n context: 'organization',\n },\n });\n }\n\n // Customer routes for backoffice\n if (!options.withBackoffice) {\n addRoutes(router, {\n parentName: routeBackoffice,\n basePath: 'customers',\n routes: routerCustomers,\n routeNamePrefix: 'Backoffice',\n filterConfig: {\n include: ['Customers'],\n },\n meta: {\n context: 'backoffice',\n },\n });\n }\n\n // Customer routes for organizations\n if (!options.withOrganizationRoutes) {\n addRoutes(router, {\n parentName: routeOrganizations,\n basePath: 'customers',\n routes: routerCustomers,\n routeNamePrefix: 'Organization',\n filterConfig: {\n include: ['Customers'],\n },\n meta: {\n context: 'organization',\n },\n });\n }\n\n // Application routes for backoffice\n if (!options.withBackoffice) {\n addRoutes(router, {\n parentName: routeBackoffice,\n basePath: 'applications',\n routes: routerApplications,\n routeNamePrefix: 'Backoffice',\n filterConfig: {\n include: ['Applications'],\n },\n meta: {\n context: 'backoffice',\n },\n });\n }\n\n // Application routes for organizations\n if (!options.withOrganizationRoutes) {\n addRoutes(router, {\n parentName: routeOrganizations,\n basePath: 'applications',\n routes: routerApplications,\n routeNamePrefix: 'Organization',\n filterConfig: {\n include: ['Applications'],\n },\n meta: {\n context: 'organization',\n },\n });\n }\n\n store.addStore('orders', storeOrders);\n store.addStore('shopcart', storeShopcart);\n store.addStore('testimonials', storeTestimonials);\n store.addStore('customers', storeCustomers);\n store.addStore('applications', storeApplications);\n}\n\nconst ModuleOrder = {\n initialize: initializeOrders,\n store: {\n storeOrders,\n storeShopcart,\n storeTestimonials,\n storeCustomers,\n storeApplications,\n },\n router: {\n routerOrders,\n routerCustomers,\n routerApplications,\n },\n components: {\n // Pages\n Orders,\n Customers,\n Applications,\n // Order,\n OrderCreate,\n OrderCreateBackoffice,\n // Favorites,\n // Blocks\n CardOrderItem,\n CardOrder,\n CardOrderUser,\n CardCustomer,\n StatusHistory,\n // Sections\n FormCustomerDetails,\n AskToLogin,\n FormDelivery,\n EmptyState,\n Succes,\n FormPayment,\n // Partials\n ShopCart,\n },\n};\n\nexport default ModuleOrder;\n"],"names":["storeShopcart.actions","routerOrders","routerCustomers","routerApplications","storeOrders","storeShopcart","storeTestimonials","storeCustomers","storeApplications","Orders","Customers","Applications","OrderCreate","OrderCreateBackoffice","CardOrderItem","CardOrderUser","StatusHistory","FormCustomerDetails","AskToLogin","FormDelivery","EmptyState","Succes","FormPayment","ShopCart"],"mappings":"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"}
@@ -1,7 +1,29 @@
1
+ import { requiresAuth } from "../../auth/views/middlewares/auth.validation.js";
2
+ import { state } from "../../auth/views/store/auth.js";
3
+ import { useGlobalMixins } from "../../core/views/mixins/mixins.js";
4
+ const { isAdmin } = useGlobalMixins();
5
+ const checkOrdersAccess = (to) => {
6
+ const context = to.matched[0]?.meta?.context;
7
+ if (context === "user") {
8
+ const isOwner = to.params._id === state.user?._id;
9
+ const roles = state.access?.roles || [];
10
+ const isAdminOrMod = isAdmin(roles) || roles.includes("ROLE_MODERATOR");
11
+ if (!isOwner && !isAdminOrMod) {
12
+ return "/401";
13
+ }
14
+ }
15
+ if (context === "backoffice") {
16
+ const roles = state.access?.roles || [];
17
+ if (!isAdmin(roles)) {
18
+ return "/401";
19
+ }
20
+ }
21
+ };
1
22
  const ordersRoutes = [
2
23
  {
3
24
  path: "",
4
25
  name: "OrdersList",
26
+ beforeEnter: [requiresAuth, checkOrdersAccess],
5
27
  component: () => import(
6
28
  /* webpackChunkName: "orders" */
7
29
  "../components/pages/Orders.vue.js"
@@ -44,6 +66,7 @@ const ordersRoutes = [
44
66
  {
45
67
  path: ":order",
46
68
  name: "Order",
69
+ beforeEnter: [requiresAuth, checkOrdersAccess],
47
70
  component: () => import(
48
71
  /* webpackChunkName: "orders" */
49
72
  "../components/pages/OrderBackoffice.vue.js"
@@ -1 +1 @@
1
- {"version":3,"file":"orders.router.js","sources":["../../../../../../src/modules/orders/router/orders.router.js"],"sourcesContent":["// Use dynamic imports for better code splitting\n\nconst ordersRoutes = [\n {\n path: '',\n name: 'OrdersList',\n component: () => import(/* webpackChunkName: \"orders\" */ '@martyrs/src/modules/orders/components/pages/Orders.vue'),\n meta: {\n title: {\n en: 'Orders',\n ru: 'Заказы',\n },\n },\n },\n {\n path: 'form',\n name: 'CreateOrder',\n component: () => import(/* webpackChunkName: \"orders\" */ '@martyrs/src/modules/orders/components/pages/OrderCreate.vue'),\n meta: {\n title: {\n en: 'Create Order',\n ru: 'Создать Заказ',\n },\n },\n },\n {\n path: 'add',\n name: 'AdminCreateOrder',\n component: () => import(/* webpackChunkName: \"orders\" */ '@martyrs/src/modules/orders/components/pages/OrderCreateBackoffice.vue'),\n meta: {\n title: {\n en: 'Add Order',\n ru: 'Добавить Заказ',\n },\n },\n },\n {\n path: ':order',\n name: 'Order',\n component: () => import(/* webpackChunkName: \"orders\" */ '@martyrs/src/modules/orders/components/pages/OrderBackoffice.vue'),\n props: route => ({\n mode: route.matched[0].meta.context === 'backoffice' ? 'edit' : 'view',\n }),\n meta: {\n title: {\n en: 'Order',\n ru: 'Заказ',\n },\n },\n },\n {\n path: ':order/edit',\n name: 'OrderEdit',\n component: () => import(/* webpackChunkName: \"orders\" */ '@martyrs/src/modules/orders/components/pages/OrderBackoffice.vue'),\n props: { mode: 'edit' },\n meta: {\n title: {\n en: 'Edit Order',\n ru: 'Редактировать Заказ',\n },\n },\n },\n];\n\nexport default ordersRoutes;\n"],"names":[],"mappings":"AAEK,MAAC,eAAe;AAAA,EACnB;AAAA,IACE,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW,MAAM;AAAA;AAAA,MAAwC;AAAA,IAAyD;AAAA,IAClH,MAAM;AAAA,MACJ,OAAO;AAAA,QACL,IAAI;AAAA,QACJ,IAAI;AAAA,MACZ;AAAA,IACA;AAAA,EACA;AAAA,EACE;AAAA,IACE,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW,MAAM;AAAA;AAAA,MAAwC;AAAA,IAA8D;AAAA,IACvH,MAAM;AAAA,MACJ,OAAO;AAAA,QACL,IAAI;AAAA,QACJ,IAAI;AAAA,MACZ;AAAA,IACA;AAAA,EACA;AAAA,EACE;AAAA,IACE,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW,MAAM;AAAA;AAAA,MAAwC;AAAA,IAAwE;AAAA,IACjI,MAAM;AAAA,MACJ,OAAO;AAAA,QACL,IAAI;AAAA,QACJ,IAAI;AAAA,MACZ;AAAA,IACA;AAAA,EACA;AAAA,EACE;AAAA,IACE,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW,MAAM;AAAA;AAAA,MAAwC;AAAA,IAAkE;AAAA,IAC3H,OAAO,YAAU;AAAA,MACf,MAAM,MAAM,QAAQ,CAAC,EAAE,KAAK,YAAY,eAAe,SAAS;AAAA,IACtE;AAAA,IACI,MAAM;AAAA,MACJ,OAAO;AAAA,QACL,IAAI;AAAA,QACJ,IAAI;AAAA,MACZ;AAAA,IACA;AAAA,EACA;AAAA,EACE;AAAA,IACE,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW,MAAM;AAAA;AAAA,MAAwC;AAAA,IAAkE;AAAA,IAC3H,OAAO,EAAE,MAAM,OAAM;AAAA,IACrB,MAAM;AAAA,MACJ,OAAO;AAAA,QACL,IAAI;AAAA,QACJ,IAAI;AAAA,MACZ;AAAA,IACA;AAAA,EACA;AACA;"}
1
+ {"version":3,"file":"orders.router.js","sources":["../../../../../../src/modules/orders/router/orders.router.js"],"sourcesContent":["// Use dynamic imports for better code splitting\nimport { requiresAuth } from '@martyrs/src/modules/auth/views/middlewares/auth.validation.js';\nimport * as auth from '@martyrs/src/modules/auth/views/store/auth.js';\nimport { useGlobalMixins } from '@martyrs/src/modules/core/views/mixins/mixins.js';\n\nconst { isAdmin } = useGlobalMixins();\n\n// Проверка доступа к заказам пользователя\nconst checkOrdersAccess = (to) => {\n const context = to.matched[0]?.meta?.context;\n\n // User контекст: владелец, модератор или админ\n if (context === 'user') {\n const isOwner = to.params._id === auth.state.user?._id;\n const roles = auth.state.access?.roles || [];\n const isAdminOrMod = isAdmin(roles) || roles.includes('ROLE_MODERATOR');\n if (!isOwner && !isAdminOrMod) {\n return '/401';\n }\n }\n\n // Backoffice контекст: только админы\n if (context === 'backoffice') {\n const roles = auth.state.access?.roles || [];\n if (!isAdmin(roles)) {\n return '/401';\n }\n }\n\n // Organization контекст - пока пропускаем (там ABAC на бэкенде)\n // Root контекст - публичный\n};\n\nconst ordersRoutes = [\n {\n path: '',\n name: 'OrdersList',\n beforeEnter: [requiresAuth, checkOrdersAccess],\n component: () => import(/* webpackChunkName: \"orders\" */ '@martyrs/src/modules/orders/components/pages/Orders.vue'),\n meta: {\n title: {\n en: 'Orders',\n ru: 'Заказы',\n },\n },\n },\n {\n path: 'form',\n name: 'CreateOrder',\n component: () => import(/* webpackChunkName: \"orders\" */ '@martyrs/src/modules/orders/components/pages/OrderCreate.vue'),\n meta: {\n title: {\n en: 'Create Order',\n ru: 'Создать Заказ',\n },\n },\n },\n {\n path: 'add',\n name: 'AdminCreateOrder',\n component: () => import(/* webpackChunkName: \"orders\" */ '@martyrs/src/modules/orders/components/pages/OrderCreateBackoffice.vue'),\n meta: {\n title: {\n en: 'Add Order',\n ru: 'Добавить Заказ',\n },\n },\n },\n {\n path: ':order',\n name: 'Order',\n beforeEnter: [requiresAuth, checkOrdersAccess],\n component: () => import(/* webpackChunkName: \"orders\" */ '@martyrs/src/modules/orders/components/pages/OrderBackoffice.vue'),\n props: route => ({\n mode: route.matched[0].meta.context === 'backoffice' ? 'edit' : 'view',\n }),\n meta: {\n title: {\n en: 'Order',\n ru: 'Заказ',\n },\n },\n },\n {\n path: ':order/edit',\n name: 'OrderEdit',\n component: () => import(/* webpackChunkName: \"orders\" */ '@martyrs/src/modules/orders/components/pages/OrderBackoffice.vue'),\n props: { mode: 'edit' },\n meta: {\n title: {\n en: 'Edit Order',\n ru: 'Редактировать Заказ',\n },\n },\n },\n];\n\nexport default ordersRoutes;\n"],"names":["auth.state"],"mappings":";;;AAKA,MAAM,EAAE,QAAO,IAAK,gBAAe;AAGnC,MAAM,oBAAoB,CAAC,OAAO;AAChC,QAAM,UAAU,GAAG,QAAQ,CAAC,GAAG,MAAM;AAGrC,MAAI,YAAY,QAAQ;AACtB,UAAM,UAAU,GAAG,OAAO,QAAQA,MAAW,MAAM;AACnD,UAAM,QAAQA,MAAW,QAAQ,SAAS,CAAA;AAC1C,UAAM,eAAe,QAAQ,KAAK,KAAK,MAAM,SAAS,gBAAgB;AACtE,QAAI,CAAC,WAAW,CAAC,cAAc;AAC7B,aAAO;AAAA,IACT;AAAA,EACF;AAGA,MAAI,YAAY,cAAc;AAC5B,UAAM,QAAQA,MAAW,QAAQ,SAAS,CAAA;AAC1C,QAAI,CAAC,QAAQ,KAAK,GAAG;AACnB,aAAO;AAAA,IACT;AAAA,EACF;AAIF;AAEK,MAAC,eAAe;AAAA,EACnB;AAAA,IACE,MAAM;AAAA,IACN,MAAM;AAAA,IACN,aAAa,CAAC,cAAc,iBAAiB;AAAA,IAC7C,WAAW,MAAM;AAAA;AAAA,MAAwC;AAAA,IAAyD;AAAA,IAClH,MAAM;AAAA,MACJ,OAAO;AAAA,QACL,IAAI;AAAA,QACJ,IAAI;AAAA,MACZ;AAAA,IACA;AAAA,EACA;AAAA,EACE;AAAA,IACE,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW,MAAM;AAAA;AAAA,MAAwC;AAAA,IAA8D;AAAA,IACvH,MAAM;AAAA,MACJ,OAAO;AAAA,QACL,IAAI;AAAA,QACJ,IAAI;AAAA,MACZ;AAAA,IACA;AAAA,EACA;AAAA,EACE;AAAA,IACE,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW,MAAM;AAAA;AAAA,MAAwC;AAAA,IAAwE;AAAA,IACjI,MAAM;AAAA,MACJ,OAAO;AAAA,QACL,IAAI;AAAA,QACJ,IAAI;AAAA,MACZ;AAAA,IACA;AAAA,EACA;AAAA,EACE;AAAA,IACE,MAAM;AAAA,IACN,MAAM;AAAA,IACN,aAAa,CAAC,cAAc,iBAAiB;AAAA,IAC7C,WAAW,MAAM;AAAA;AAAA,MAAwC;AAAA,IAAkE;AAAA,IAC3H,OAAO,YAAU;AAAA,MACf,MAAM,MAAM,QAAQ,CAAC,EAAE,KAAK,YAAY,eAAe,SAAS;AAAA,IACtE;AAAA,IACI,MAAM;AAAA,MACJ,OAAO;AAAA,QACL,IAAI;AAAA,QACJ,IAAI;AAAA,MACZ;AAAA,IACA;AAAA,EACA;AAAA,EACE;AAAA,IACE,MAAM;AAAA,IACN,MAAM;AAAA,IACN,WAAW,MAAM;AAAA;AAAA,MAAwC;AAAA,IAAkE;AAAA,IAC3H,OAAO,EAAE,MAAM,OAAM;AAAA,IACrB,MAAM;AAAA,MACJ,OAAO;AAAA,QACL,IAAI;AAAA,QACJ,IAAI;AAAA,MACZ;AAAA,IACA;AAAA,EACA;AACA;"}
@@ -1,5 +1,5 @@
1
1
  import { createElementBlock, openBlock, createElementVNode, createCommentVNode, Fragment, renderList, createBlock } from "vue";
2
- /* empty css */
2
+ /* empty css */
3
3
  import "../../organizations.client.js";
4
4
  import _sfc_main$1 from "../../../auth/views/components/blocks/CardUser.vue.js";
5
5
  /* empty css */
@@ -22,7 +22,7 @@ const _hoisted_6 = {
22
22
  const _hoisted_7 = { class: "truncate" };
23
23
  const _hoisted_8 = {
24
24
  key: 0,
25
- class: "mn-b-small t-nowrap mn-t-small w-100 flex-nowrap flex flex-v-center pd-small bg-white radius-medium"
25
+ class: "mn-b-small ws-nowrap mn-t-small w-100 flex-nowrap flex flex-v-center pd-small bg-white radius-medium"
26
26
  };
27
27
  const _hoisted_9 = { class: "mn-r-micro" };
28
28
  const _hoisted_10 = {
@@ -1 +1 @@
1
- {"version":3,"file":"CardOrganization.vue.js","sources":["../../../../../../../src/modules/organizations/components/blocks/CardOrganization.vue"],"sourcesContent":["<template>\n <div\n class=\"o-hidden pos-relative cursor-pointer bg-light \"\n @click=\"$router.push('/organizations/' + organization._id)\"\n >\n <div class=\"h-4r flex pos-relative\">\n\n <img loading=\"lazy\" \n v-if=\"organization.profile.photo && organization.profile.photo.length > 0\"\n :src=\"(FILE_SERVER_URL || '') + organization.profile.photo\" \n class=\"h-4r w-4r radius-extra bg-white\" \n style=\"flex: 0 1 auto\"\n />\n\n <PlaceholderOrganizationPic\n v-else\n class=\"w-4r h-max radius-medium\"\n style=\"flex: 0 1 auto\"\n />\n \n <div class=\"pos-relative w-100 flex-h-center flex flex-column flex-child-1 flex-child mn-l-thin w-100\">\n \n <!-- <Text :text=\"organization.profile.name ? organization.profile.name : ''\" :maxLen=\"18\" class=\"h3 d-block\"/> -->\n <p class=\"h4 truncate w-100\">{{organization.profile.name}}</p>\n <!-- RATING -->\n <!-- <div v-if=\"showRating && organization.rating\" class=\"w-max star-container flex-v-center flex\">\n <img loading=\"lazy\" \n v-for=\"i in 5\"\n class=\"i-small mn-r-thin\"\n :src=\"i <= organization.rating.median ? '/icons/star.svg' : '/icons/star-stroke.svg'\"\n >\n\n <span class=\"p-small fw-semi mn-r-thin\">{{organization.rating.median}}</span>\n <span class=\"p-small\">({{organization.rating.amount}})</span>\n </div> -->\n\n <div v-if=\"showFollowers || showTags\" class=\"mn-t-micro gap-micro flex-nowrap flex\">\n\n <Chips \n v-if=\"showTags && organization.profile.tags?.length > 0\" \n :chips=\"organization.profile.tags.slice(0,3)\"\n class=\"pos-relative t-trimmed\"\n >\n <div v-if=\"showFollowers\" class=\"truncate pos-relative p-regular mn-r-nano d-inline-block w-max pd-b-micro pd-t-micro pd-r-thin pd-l-thin radius-small fw-medium bg-white\">\n <p class=\"truncate\">{{organization.numberOfSubscribers}} followers</p>\n\n <ButtonToggleMembership\n v-if=\"\n user?._id \n && organization.owner !== user._id\n \"\n :user=\"user._id\"\n :type=\"'organization'\" \n :role=\"'subscriber'\" \n :target=\"organization._id\" \n :status=\"organization.isSubscriber\" \n :text=\"{create: '+', remove: '-'}\"\n @updateMembership=\"event => emits('updateMembership', event, 'isSubscriber', 'numberOfSubscribers')\"\n class=\"i-medium\" \n />\n </div>\n </Chips>\n </div>\n\n </div>\n\n </div>\n\n\n <div \n v-if=\"showProducts && organization.products\" \n class=\"mn-b-small t-nowrap mn-t-small w-100 flex-nowrap flex flex-v-center pd-small bg-white radius-medium\"\n >\n <IconTime class=\"i-medium t-transp mn-r-micro\"/>\n <span class=\"mn-r-micro\">\n {{\n organization.distance ? \n organization.distance > 50 ? \n '3-5 days' : \n Math.ceil((5 + 5 + 3 * organization.distance) / 5) * 5 \n + '-' \n + Math.ceil((15 + 5 + 3 * organization.distance) / 5) * 5 \n + ' MIN' : 'Unavailable' \n }} \n </span>\n\n <span v-if=\"organization.distance && organization.distance < 50\" class=\"t-transp t-grey mn-r-micro\">|</span>\n <span v-if=\"organization.distance && organization.distance < 50\" class=\"mn-r-thin\">{{organization.distance ? organization.distance.toFixed(1) + 'KM' : ''}}</span>\n <!-- <span class=\"mn-r-thin\">{{organization.nearestSpotDistance}}</span> -->\n <!-- <IconPrice class=\"i-medium mn-r-micro\"/> -->\n <!-- <span class=\"mn-r-thin\">{{returnCurrency()}}500 </span> -->\n <IconShopcart class=\"i-medium t-transp mn-r-micro\"/>\n <span class=\"mn-r-thin\"> {{organization.products.length}} products</span>\n </div>\n\n <div v-if=\"showProducts && organization.products?.length > 0\" class=\"w-100 o-scroll scroll-hide radius-medium\">\n <div class=\"w-max flex-nowrap flex gap-thin\">\n <CardOrderItem\n @click.stop=\"$router.push(`/organizations/${organization._id}/products/${product._id}`)\"\n v-for=\"product in organization.products.slice(0,5)\"\n :key=\"product._id\"\n :editable=\"false\"\n :productId=\"product._id\"\n :variantId=\"product.variants?.[0]?._id\"\n :images=\"product.images\"\n :name=\"product.name\"\n :quantity=\"product.variants?.[0]?.quantity || 1\"\n :unit=\"product.variants?.[0]?.unit\"\n :dates=\"product.date\"\n :listing=\"product.listing\"\n :price=\"product.variants?.[0]?.price\"\n class=\"pd-thin w-15r radius-medium bg-white\"\n\n />\n <button class=\"pd-thin w-15r radius-medium bg-main button\">\n View menu\n </button>\n </div>\n </div>\n\n </div>\n</template>\n\n<script setup>\n import { ref } from 'vue'\n import { useRouter } from 'vue-router'\n import CardOrderItem from '@martyrs/src/modules/orders/components/blocks/CardOrderItem.vue';\n\n import Text from '@martyrs/src/components/Text/Text.vue'\n import Chips from '@martyrs/src/components/Chips/Chips.vue'\n\n import PlaceholderOrganizationPic from '@martyrs/src/modules/icons/placeholders/PlaceholderOrganizationPic.vue'\n\n import IconPrice from '@martyrs/src/modules/icons/entities/IconPrice.vue'\n import IconShopcart from '@martyrs/src/modules/icons/entities/IconShopcart.vue'\n import IconTime from '@martyrs/src/modules/icons/entities/IconTime.vue'\n\n import ButtonToggleMembership from '@martyrs/src/modules/organizations/components/elements/ButtonToggleMembership.vue'\n\n const props = defineProps({\n // Model\n user: String,\n organization: Object,\n // View\n showProducts: {\n type: Boolean,\n default: false\n },\n showFollowers: {\n type: Boolean,\n default: true\n },\n showRating: {\n type: Boolean,\n default: false\n },\n showFeatured: {\n type: Boolean,\n default: true\n },\n showTags: {\n type: Boolean,\n default: true\n },\n });\n\n const emits = defineEmits(['updateMembership'])\n\n const router = useRouter();\n</script>\n\n<style>\n\n.t-trimmed {\n font-size: 0;\n}\n</style>"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAsKE,UAAM,QAAQ;AAEC,cAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"CardOrganization.vue.js","sources":["../../../../../../../src/modules/organizations/components/blocks/CardOrganization.vue"],"sourcesContent":["<template>\n <div\n class=\"o-hidden pos-relative cursor-pointer bg-light \"\n @click=\"$router.push('/organizations/' + organization._id)\"\n >\n <div class=\"h-4r flex pos-relative\">\n\n <img loading=\"lazy\" \n v-if=\"organization.profile.photo && organization.profile.photo.length > 0\"\n :src=\"(FILE_SERVER_URL || '') + organization.profile.photo\" \n class=\"h-4r w-4r radius-extra bg-white\" \n style=\"flex: 0 1 auto\"\n />\n\n <PlaceholderOrganizationPic\n v-else\n class=\"w-4r h-max radius-medium\"\n style=\"flex: 0 1 auto\"\n />\n \n <div class=\"pos-relative w-100 flex-h-center flex flex-column flex-child-1 flex-child mn-l-thin w-100\">\n \n <!-- <Text :text=\"organization.profile.name ? organization.profile.name : ''\" :maxLen=\"18\" class=\"h3 d-block\"/> -->\n <p class=\"h4 truncate w-100\">{{organization.profile.name}}</p>\n <!-- RATING -->\n <!-- <div v-if=\"showRating && organization.rating\" class=\"w-max star-container flex-v-center flex\">\n <img loading=\"lazy\" \n v-for=\"i in 5\"\n class=\"i-small mn-r-thin\"\n :src=\"i <= organization.rating.median ? '/icons/star.svg' : '/icons/star-stroke.svg'\"\n >\n\n <span class=\"p-small fw-semi mn-r-thin\">{{organization.rating.median}}</span>\n <span class=\"p-small\">({{organization.rating.amount}})</span>\n </div> -->\n\n <div v-if=\"showFollowers || showTags\" class=\"mn-t-micro gap-micro flex-nowrap flex\">\n\n <Chips \n v-if=\"showTags && organization.profile.tags?.length > 0\" \n :chips=\"organization.profile.tags.slice(0,3)\"\n class=\"pos-relative t-trimmed\"\n >\n <div v-if=\"showFollowers\" class=\"truncate pos-relative p-regular mn-r-nano d-inline-block w-max pd-b-micro pd-t-micro pd-r-thin pd-l-thin radius-small fw-medium bg-white\">\n <p class=\"truncate\">{{organization.numberOfSubscribers}} followers</p>\n\n <ButtonToggleMembership\n v-if=\"\n user?._id \n && organization.owner !== user._id\n \"\n :user=\"user._id\"\n :type=\"'organization'\" \n :role=\"'subscriber'\" \n :target=\"organization._id\" \n :status=\"organization.isSubscriber\" \n :text=\"{create: '+', remove: '-'}\"\n @updateMembership=\"event => emits('updateMembership', event, 'isSubscriber', 'numberOfSubscribers')\"\n class=\"i-medium\" \n />\n </div>\n </Chips>\n </div>\n\n </div>\n\n </div>\n\n\n <div \n v-if=\"showProducts && organization.products\" \n class=\"mn-b-small ws-nowrap mn-t-small w-100 flex-nowrap flex flex-v-center pd-small bg-white radius-medium\"\n >\n <IconTime class=\"i-medium t-transp mn-r-micro\"/>\n <span class=\"mn-r-micro\">\n {{\n organization.distance ? \n organization.distance > 50 ? \n '3-5 days' : \n Math.ceil((5 + 5 + 3 * organization.distance) / 5) * 5 \n + '-' \n + Math.ceil((15 + 5 + 3 * organization.distance) / 5) * 5 \n + ' MIN' : 'Unavailable' \n }} \n </span>\n\n <span v-if=\"organization.distance && organization.distance < 50\" class=\"t-transp t-grey mn-r-micro\">|</span>\n <span v-if=\"organization.distance && organization.distance < 50\" class=\"mn-r-thin\">{{organization.distance ? organization.distance.toFixed(1) + 'KM' : ''}}</span>\n <!-- <span class=\"mn-r-thin\">{{organization.nearestSpotDistance}}</span> -->\n <!-- <IconPrice class=\"i-medium mn-r-micro\"/> -->\n <!-- <span class=\"mn-r-thin\">{{returnCurrency()}}500 </span> -->\n <IconShopcart class=\"i-medium t-transp mn-r-micro\"/>\n <span class=\"mn-r-thin\"> {{organization.products.length}} products</span>\n </div>\n\n <div v-if=\"showProducts && organization.products?.length > 0\" class=\"w-100 o-scroll scroll-hide radius-medium\">\n <div class=\"w-max flex-nowrap flex gap-thin\">\n <CardOrderItem\n @click.stop=\"$router.push(`/organizations/${organization._id}/products/${product._id}`)\"\n v-for=\"product in organization.products.slice(0,5)\"\n :key=\"product._id\"\n :editable=\"false\"\n :productId=\"product._id\"\n :variantId=\"product.variants?.[0]?._id\"\n :images=\"product.images\"\n :name=\"product.name\"\n :quantity=\"product.variants?.[0]?.quantity || 1\"\n :unit=\"product.variants?.[0]?.unit\"\n :dates=\"product.date\"\n :listing=\"product.listing\"\n :price=\"product.variants?.[0]?.price\"\n class=\"pd-thin w-15r radius-medium bg-white\"\n\n />\n <button class=\"pd-thin w-15r radius-medium bg-main button\">\n View menu\n </button>\n </div>\n </div>\n\n </div>\n</template>\n\n<script setup>\n import { ref } from 'vue'\n import { useRouter } from 'vue-router'\n import CardOrderItem from '@martyrs/src/modules/orders/components/blocks/CardOrderItem.vue';\n\n import Text from '@martyrs/src/components/Text/Text.vue'\n import Chips from '@martyrs/src/components/Chips/Chips.vue'\n\n import PlaceholderOrganizationPic from '@martyrs/src/modules/icons/placeholders/PlaceholderOrganizationPic.vue'\n\n import IconPrice from '@martyrs/src/modules/icons/entities/IconPrice.vue'\n import IconShopcart from '@martyrs/src/modules/icons/entities/IconShopcart.vue'\n import IconTime from '@martyrs/src/modules/icons/entities/IconTime.vue'\n\n import ButtonToggleMembership from '@martyrs/src/modules/organizations/components/elements/ButtonToggleMembership.vue'\n\n const props = defineProps({\n // Model\n user: String,\n organization: Object,\n // View\n showProducts: {\n type: Boolean,\n default: false\n },\n showFollowers: {\n type: Boolean,\n default: true\n },\n showRating: {\n type: Boolean,\n default: false\n },\n showFeatured: {\n type: Boolean,\n default: true\n },\n showTags: {\n type: Boolean,\n default: true\n },\n });\n\n const emits = defineEmits(['updateMembership'])\n\n const router = useRouter();\n</script>\n\n<style>\n\n.t-trimmed {\n font-size: 0;\n}\n</style>"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAsKE,UAAM,QAAQ;AAEC,cAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -1,5 +1,5 @@
1
1
  import { createBlock, openBlock, withCtx, createTextVNode, toDisplayString } from "vue";
2
- import _sfc_main$1 from "../../../../components/Button/Button.vue.js";
2
+ import _sfc_main$1 from "../../../../components/Button/Button.vue2.js";
3
3
  import membershipsStore from "../../store/memberships.store.js";
4
4
  const _sfc_main = {
5
5
  __name: "ButtonToggleMembership",
@@ -1,5 +1,5 @@
1
1
  import { ref, createElementBlock, openBlock, createElementVNode, createVNode, createCommentVNode, withCtx, Fragment, renderList, normalizeClass, createBlock, toDisplayString, createTextVNode } from "vue";
2
- import _sfc_main$3 from "../../../../components/Button/Button.vue.js";
2
+ import _sfc_main$3 from "../../../../components/Button/Button.vue2.js";
3
3
  import _sfc_main$1 from "../../../../components/Feed/Feed.vue.js";
4
4
  import PlaceholderUserpic from "../../../icons/placeholders/PlaceholderUserpic.vue.js";
5
5
  import _sfc_main$2 from "../../../icons/navigation/IconCheck.vue.js";
@@ -3,11 +3,11 @@ import { useRoute } from "vue-router";
3
3
  import UploadImage from "../../../../components/UploadImage/UploadImage.vue.js";
4
4
  import Field from "../../../../components/Field/Field.vue.js";
5
5
  import _sfc_main$4 from "../../../../components/Checkbox/Checkbox.vue.js";
6
- import _sfc_main$6 from "../../../../components/Button/Button.vue.js";
6
+ import _sfc_main$6 from "../../../../components/Button/Button.vue2.js";
7
7
  import _sfc_main$7 from "../../../../components/Popup/Popup.vue.js";
8
8
  import _sfc_main$1 from "../../../../components/Block/Block.vue.js";
9
9
  import _sfc_main$8 from "../../../../components/Feed/Feed.vue.js";
10
- import _sfc_main$5 from "../../../../components/Spoiler/Spoiler.vue.js";
10
+ import _sfc_main$5 from "../../../../components/Spoiler/Spoiler.vue2.js";
11
11
  import _sfc_main$2 from "../../../auth/views/components/blocks/CardUser.vue.js";
12
12
  import _sfc_main$3 from "../../../icons/navigation/IconDelete.vue.js";
13
13
  import { useStore } from "../../../core/views/store/core.store.js";
@@ -1,6 +1,6 @@
1
1
  import { ref, createElementBlock, openBlock, createElementVNode, createVNode, toDisplayString, Fragment, renderList, withCtx } from "vue";
2
2
  import Field from "../../../../components/Field/Field.vue.js";
3
- import _sfc_main$3 from "../../../../components/Button/Button.vue.js";
3
+ import _sfc_main$3 from "../../../../components/Button/Button.vue2.js";
4
4
  import _sfc_main$2 from "../../../icons/navigation/IconDelete.vue.js";
5
5
  import _sfc_main$1 from "../../../icons/navigation/IconAdd.vue.js";
6
6
  const _hoisted_1 = { class: "mn-b-thin t-transp p-regular" };
@@ -1,6 +1,6 @@
1
1
  import { withAsyncContext, resolveComponent, createElementBlock, openBlock, createCommentVNode, unref, createElementVNode, createVNode, toDisplayString, withCtx, Fragment, renderList, createBlock } from "vue";
2
2
  import { useRouter, useRoute } from "vue-router";
3
- /* empty css */
3
+ /* empty css */
4
4
  import "../../organizations.client.js";
5
5
  import _sfc_main$2 from "../../../auth/views/components/blocks/CardUser.vue.js";
6
6
  import _sfc_main$1 from "../../../icons/navigation/IconEdit.vue.js";