@ozdao/martyrs 0.2.518 → 0.2.520
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/_virtual/index.cjs +4 -4
- package/dist/_virtual/index.js +4 -4
- package/dist/_virtual/index2.cjs +4 -4
- package/dist/_virtual/index2.js +4 -4
- package/dist/{abac-Cf_9lCSh.js → abac-CnJsrv8S.js} +3 -3
- package/dist/{abac-6LjoG9u-.cjs → abac-DOyUjhee.cjs} +3 -3
- package/dist/builder.cjs +27 -25
- package/dist/builder.js +27 -25
- package/dist/chats.server.cjs +198 -1
- package/dist/chats.server.js +198 -1
- package/dist/{crud-sE7GLPbj.js → crud-BIFl1W1i.js} +6 -6
- package/dist/{crud-JN_LFj01.cjs → crud-CC6k6yY5.cjs} +6 -6
- package/dist/{globals.logger-CZMgIMlM.cjs → globals.logger-BuW7JHMY.cjs} +63 -53
- package/dist/{globals.logger-Bf6rRU7j.js → globals.logger-VRHh-WUW.js} +63 -53
- package/dist/{globals.observer-CV2wCzzh.cjs → globals.observer-C_FYclgV.cjs} +36 -1
- package/dist/{globals.observer-CDqUjVU5.js → globals.observer-MZsqaE6F.js} +36 -1
- package/dist/globals.server.cjs +1 -1
- package/dist/globals.server.js +1 -1
- package/dist/inventory.server.cjs +276 -376
- package/dist/inventory.server.js +276 -376
- package/dist/main-BM3GslOO.cjs +11 -0
- package/dist/{main-wmEhGVvD.js → main-Qcn7YlTx.js} +1834 -1830
- package/dist/martyrs/src/components/Address/{Address.vue2.cjs → Address.vue.cjs} +2 -2
- package/dist/martyrs/src/components/Address/{Address.vue2.js.map → Address.vue.cjs.map} +1 -1
- package/dist/martyrs/src/components/Address/{Address.vue2.js → Address.vue.js} +2 -2
- package/dist/martyrs/src/components/Address/Address.vue.js.map +1 -0
- package/dist/martyrs/src/components/Button/Button.vue.cjs +1 -1
- package/dist/martyrs/src/components/Button/Button.vue.cjs.map +1 -1
- package/dist/martyrs/src/components/Button/Button.vue.js +1 -1
- package/dist/martyrs/src/components/Button/Button.vue.js.map +1 -1
- package/dist/martyrs/src/components/Chips/{Chips.vue.cjs → Chips.vue2.cjs} +2 -2
- package/dist/martyrs/src/components/Chips/Chips.vue2.cjs.map +1 -0
- package/dist/martyrs/src/components/Chips/{Chips.vue.js → Chips.vue2.js} +2 -2
- package/dist/martyrs/src/components/Chips/Chips.vue2.js.map +1 -0
- package/dist/martyrs/src/components/Dropdown/{Dropdown.vue.cjs → Dropdown.vue2.cjs} +2 -2
- package/dist/martyrs/src/components/Dropdown/Dropdown.vue2.cjs.map +1 -0
- package/dist/martyrs/src/components/Dropdown/{Dropdown.vue.js → Dropdown.vue2.js} +2 -2
- package/dist/martyrs/src/components/Dropdown/{Dropdown.vue.cjs.map → Dropdown.vue2.js.map} +1 -1
- package/dist/martyrs/src/components/EditImages/EditImages.vue.cjs +0 -93
- package/dist/martyrs/src/components/EditImages/EditImages.vue.cjs.map +1 -1
- package/dist/martyrs/src/components/EditImages/EditImages.vue.js +1 -94
- package/dist/martyrs/src/components/EditImages/EditImages.vue.js.map +1 -1
- package/dist/martyrs/src/components/EditImages/EditImages.vue2.cjs +93 -0
- package/dist/martyrs/src/components/EditImages/EditImages.vue2.cjs.map +1 -1
- package/dist/martyrs/src/components/EditImages/EditImages.vue2.js +94 -1
- package/dist/martyrs/src/components/EditImages/EditImages.vue2.js.map +1 -1
- package/dist/martyrs/src/components/Feed/Feed.vue.cjs +2 -3
- package/dist/martyrs/src/components/Feed/Feed.vue.cjs.map +1 -1
- package/dist/martyrs/src/components/Feed/Feed.vue.js +2 -3
- package/dist/martyrs/src/components/Feed/Feed.vue.js.map +1 -1
- package/dist/martyrs/src/components/FieldTags/FieldTags.vue.cjs +1 -1
- package/dist/martyrs/src/components/FieldTags/FieldTags.vue.js +1 -1
- package/dist/martyrs/src/components/Loader/Loader.vue2.cjs +1 -1
- package/dist/martyrs/src/components/Loader/Loader.vue2.cjs.map +1 -1
- package/dist/martyrs/src/components/Loader/Loader.vue2.js +1 -1
- package/dist/martyrs/src/components/Loader/Loader.vue2.js.map +1 -1
- package/dist/martyrs/src/components/LocationMarker/{LocationMarker.vue2.cjs → LocationMarker.vue.cjs} +2 -2
- package/dist/martyrs/src/components/LocationMarker/{LocationMarker.vue2.js.map → LocationMarker.vue.cjs.map} +1 -1
- package/dist/martyrs/src/components/LocationMarker/{LocationMarker.vue2.js → LocationMarker.vue.js} +2 -2
- package/dist/martyrs/src/components/LocationMarker/LocationMarker.vue.js.map +1 -0
- package/dist/martyrs/src/components/Select/{Select.vue2.cjs → Select.vue.cjs} +2 -2
- package/dist/martyrs/src/components/Select/{Select.vue2.js.map → Select.vue.cjs.map} +1 -1
- package/dist/martyrs/src/components/Select/{Select.vue2.js → Select.vue.js} +2 -2
- package/dist/martyrs/src/components/Select/Select.vue.js.map +1 -0
- package/dist/martyrs/src/modules/auth/views/components/blocks/CardUser.vue.cjs +2 -2
- package/dist/martyrs/src/modules/auth/views/components/blocks/CardUser.vue.js +2 -2
- package/dist/martyrs/src/modules/auth/views/components/layouts/Auth.vue.cjs +1 -1
- package/dist/martyrs/src/modules/auth/views/components/layouts/Auth.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/auth/views/components/layouts/Auth.vue.js +1 -1
- package/dist/martyrs/src/modules/auth/views/components/layouts/Auth.vue.js.map +1 -1
- 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.cjs.map +1 -1
- package/dist/martyrs/src/modules/auth/views/components/pages/Invite.vue.js +4 -4
- package/dist/martyrs/src/modules/auth/views/components/pages/Invite.vue.js.map +1 -1
- package/dist/martyrs/src/modules/auth/views/components/pages/Profile.vue.cjs +41 -51
- 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 +59 -69
- package/dist/martyrs/src/modules/auth/views/components/pages/Profile.vue.js.map +1 -1
- package/dist/martyrs/src/modules/auth/views/components/sections/SliderFeatures.vue.cjs +11 -13
- package/dist/martyrs/src/modules/auth/views/components/sections/SliderFeatures.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/auth/views/components/sections/SliderFeatures.vue.js +11 -13
- package/dist/martyrs/src/modules/auth/views/components/sections/SliderFeatures.vue.js.map +1 -1
- package/dist/martyrs/src/modules/auth/views/store/auth.cjs +10 -1
- package/dist/martyrs/src/modules/auth/views/store/auth.cjs.map +1 -1
- package/dist/martyrs/src/modules/auth/views/store/auth.js +10 -1
- package/dist/martyrs/src/modules/auth/views/store/auth.js.map +1 -1
- package/dist/martyrs/src/modules/backoffice/components/partials/Sidebar.vue.cjs +6 -0
- package/dist/martyrs/src/modules/backoffice/components/partials/Sidebar.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/backoffice/components/partials/Sidebar.vue.js +6 -0
- package/dist/martyrs/src/modules/backoffice/components/partials/Sidebar.vue.js.map +1 -1
- package/dist/martyrs/src/modules/chats/components/blocks/ChatMessage.vue.cjs +27 -11
- package/dist/martyrs/src/modules/chats/components/blocks/ChatMessage.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/chats/components/blocks/ChatMessage.vue.js +28 -12
- package/dist/martyrs/src/modules/chats/components/blocks/ChatMessage.vue.js.map +1 -1
- package/dist/martyrs/src/modules/chats/components/sections/ChatWindow.vue.cjs +62 -0
- package/dist/martyrs/src/modules/chats/components/sections/ChatWindow.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/chats/components/sections/ChatWindow.vue.js +63 -1
- package/dist/martyrs/src/modules/chats/components/sections/ChatWindow.vue.js.map +1 -1
- package/dist/martyrs/src/modules/chats/store/chat.store.cjs +60 -1
- package/dist/martyrs/src/modules/chats/store/chat.store.cjs.map +1 -1
- package/dist/martyrs/src/modules/chats/store/chat.store.js +60 -1
- package/dist/martyrs/src/modules/chats/store/chat.store.js.map +1 -1
- 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/layouts/Community.vue.cjs +3 -3
- package/dist/martyrs/src/modules/community/components/layouts/Community.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/community/components/layouts/Community.vue.js +3 -3
- package/dist/martyrs/src/modules/community/components/layouts/Community.vue.js.map +1 -1
- package/dist/martyrs/src/modules/community/components/pages/BlogPost.vue.cjs +2 -2
- package/dist/martyrs/src/modules/community/components/pages/BlogPost.vue.js +2 -2
- package/dist/martyrs/src/modules/community/components/pages/CreateBlogPost.vue.cjs +1 -1
- package/dist/martyrs/src/modules/community/components/pages/CreateBlogPost.vue.js +1 -1
- package/dist/martyrs/src/modules/community/components/pages/Posts.vue.cjs +50 -368
- package/dist/martyrs/src/modules/community/components/pages/Posts.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/community/components/pages/Posts.vue.js +53 -371
- package/dist/martyrs/src/modules/community/components/pages/Posts.vue.js.map +1 -1
- 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/pages/EditEvent.vue.cjs +1 -1
- package/dist/martyrs/src/modules/events/components/pages/EditEvent.vue.js +1 -1
- package/dist/martyrs/src/modules/events/components/pages/EditEventTickets.vue.cjs +1 -1
- package/dist/martyrs/src/modules/events/components/pages/EditEventTickets.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/events/components/pages/EditEventTickets.vue.js +1 -1
- package/dist/martyrs/src/modules/events/components/pages/EditEventTickets.vue.js.map +1 -1
- package/dist/martyrs/src/modules/events/components/pages/Event.vue.cjs +2 -3
- 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 +2 -3
- 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 +2 -2
- package/dist/martyrs/src/modules/events/components/pages/Events.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/events/components/pages/Events.vue.js +2 -2
- package/dist/martyrs/src/modules/events/components/pages/Events.vue.js.map +1 -1
- package/dist/martyrs/src/modules/gallery/components/sections/BackofficeGallery.vue.cjs +3 -3
- package/dist/martyrs/src/modules/gallery/components/sections/BackofficeGallery.vue.js +3 -3
- package/dist/martyrs/src/modules/globals/views/classes/globals.i18n.cjs +1 -1
- package/dist/martyrs/src/modules/globals/views/classes/globals.i18n.js +1 -1
- package/dist/martyrs/src/modules/globals/views/components/blocks/CardHeader.vue.cjs +2 -2
- package/dist/martyrs/src/modules/globals/views/components/blocks/CardHeader.vue.js +2 -2
- package/dist/martyrs/src/modules/globals/views/components/partials/Header.vue.cjs +2 -2
- package/dist/martyrs/src/modules/globals/views/components/partials/Header.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/globals/views/components/partials/Header.vue.js +2 -2
- package/dist/martyrs/src/modules/globals/views/components/partials/Header.vue.js.map +1 -1
- package/dist/martyrs/src/modules/globals/views/components/partials/LocationSelection.vue.cjs +2 -2
- package/dist/martyrs/src/modules/globals/views/components/partials/LocationSelection.vue.js +2 -2
- package/dist/martyrs/src/modules/globals/views/components/partials/Navigation.vue.cjs +1 -1
- package/dist/martyrs/src/modules/globals/views/components/partials/Navigation.vue.js +1 -1
- package/dist/martyrs/src/modules/globals/views/components/partials/Sidebar.vue.cjs +16 -3
- package/dist/martyrs/src/modules/globals/views/components/partials/Sidebar.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/globals/views/components/partials/Sidebar.vue.js +17 -4
- package/dist/martyrs/src/modules/globals/views/components/partials/Sidebar.vue.js.map +1 -1
- package/dist/martyrs/src/modules/globals/views/components/sections/Walkthrough.vue.cjs +1 -1
- package/dist/martyrs/src/modules/globals/views/mixins/mixins.cjs +7 -0
- package/dist/martyrs/src/modules/globals/views/mixins/mixins.cjs.map +1 -1
- package/dist/martyrs/src/modules/globals/views/mixins/mixins.js +7 -0
- package/dist/martyrs/src/modules/globals/views/mixins/mixins.js.map +1 -1
- package/dist/martyrs/src/modules/icons/pages/IconsPage.vue.cjs +1 -1
- package/dist/martyrs/src/modules/inventory/components/forms/AdjustmentForm.vue.cjs +67 -43
- package/dist/martyrs/src/modules/inventory/components/forms/AdjustmentForm.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/inventory/components/forms/AdjustmentForm.vue.js +68 -44
- package/dist/martyrs/src/modules/inventory/components/forms/AdjustmentForm.vue.js.map +1 -1
- package/dist/martyrs/src/modules/inventory/components/forms/ColumnSettingsMenu.vue.cjs +22 -7
- package/dist/martyrs/src/modules/inventory/components/forms/ColumnSettingsMenu.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/inventory/components/forms/ColumnSettingsMenu.vue.js +23 -8
- package/dist/martyrs/src/modules/inventory/components/forms/ColumnSettingsMenu.vue.js.map +1 -1
- package/dist/martyrs/src/modules/inventory/components/forms/HistoryView.vue.cjs +47 -32
- package/dist/martyrs/src/modules/inventory/components/forms/HistoryView.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/inventory/components/forms/HistoryView.vue.js +48 -33
- package/dist/martyrs/src/modules/inventory/components/forms/HistoryView.vue.js.map +1 -1
- package/dist/martyrs/src/modules/inventory/components/forms/StockAlertsForm.vue.cjs +47 -26
- package/dist/martyrs/src/modules/inventory/components/forms/StockAlertsForm.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/inventory/components/forms/StockAlertsForm.vue.js +48 -27
- package/dist/martyrs/src/modules/inventory/components/forms/StockAlertsForm.vue.js.map +1 -1
- package/dist/martyrs/src/modules/inventory/components/pages/Inventory.vue.cjs +42 -52
- package/dist/martyrs/src/modules/inventory/components/pages/Inventory.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/inventory/components/pages/Inventory.vue.js +43 -53
- package/dist/martyrs/src/modules/inventory/components/pages/Inventory.vue.js.map +1 -1
- package/dist/martyrs/src/modules/inventory/components/pages/InventoryEdit.vue.cjs +18 -18
- package/dist/martyrs/src/modules/inventory/components/pages/InventoryEdit.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/inventory/components/pages/InventoryEdit.vue.js +3 -3
- package/dist/martyrs/src/modules/inventory/components/pages/InventoryEdit.vue.js.map +1 -1
- package/dist/martyrs/src/modules/inventory/store/{ inventory.store.cjs → inventory.store.cjs} +46 -2
- package/dist/martyrs/src/modules/inventory/store/inventory.store.cjs.map +1 -0
- package/dist/martyrs/src/modules/inventory/store/{ inventory.store.js → inventory.store.js} +46 -2
- package/dist/martyrs/src/modules/inventory/store/inventory.store.js.map +1 -0
- package/dist/martyrs/src/modules/marketplace/views/components/layouts/Marketplace.vue.cjs +180 -19
- package/dist/martyrs/src/modules/marketplace/views/components/layouts/Marketplace.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/marketplace/views/components/layouts/Marketplace.vue.js +181 -20
- package/dist/martyrs/src/modules/marketplace/views/components/layouts/Marketplace.vue.js.map +1 -1
- package/dist/martyrs/src/modules/music/components/forms/AlbumForm.vue.cjs +1 -1
- package/dist/martyrs/src/modules/music/components/forms/AlbumForm.vue.js +1 -1
- package/dist/martyrs/src/modules/music/components/forms/ArtistForm.vue.cjs +1 -1
- package/dist/martyrs/src/modules/music/components/forms/ArtistForm.vue.js +1 -1
- package/dist/martyrs/src/modules/music/components/forms/TrackForm.vue.cjs +1 -1
- package/dist/martyrs/src/modules/music/components/forms/TrackForm.vue.js +1 -1
- package/dist/martyrs/src/modules/music/components/pages/Album.vue.cjs +1 -1
- package/dist/martyrs/src/modules/music/components/pages/Album.vue.js +1 -1
- package/dist/martyrs/src/modules/music/components/pages/Playlist.vue.cjs +1 -1
- package/dist/martyrs/src/modules/music/components/pages/Playlist.vue.js +1 -1
- package/dist/martyrs/src/modules/music/components/pages/Track.vue.cjs +1 -1
- package/dist/martyrs/src/modules/music/components/pages/Track.vue.js +1 -1
- package/dist/martyrs/src/modules/music/router/music.cjs +1 -2
- package/dist/martyrs/src/modules/music/router/music.cjs.map +1 -1
- package/dist/martyrs/src/modules/music/router/music.js +1 -2
- package/dist/martyrs/src/modules/music/router/music.js.map +1 -1
- package/dist/martyrs/src/modules/orders/components/blocks/CardOrderBackoffice.vue.cjs +2 -2
- package/dist/martyrs/src/modules/orders/components/blocks/CardOrderBackoffice.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/orders/components/blocks/CardOrderBackoffice.vue.js +2 -2
- package/dist/martyrs/src/modules/orders/components/blocks/CardOrderBackoffice.vue.js.map +1 -1
- package/dist/martyrs/src/modules/orders/components/forms/FormApplicationDetails.vue.cjs +1 -1
- package/dist/martyrs/src/modules/orders/components/forms/FormApplicationDetails.vue.js +1 -1
- package/dist/martyrs/src/modules/orders/components/forms/FormCustomerDetails.vue.cjs +1 -1
- package/dist/martyrs/src/modules/orders/components/forms/FormCustomerDetails.vue.js +1 -1
- package/dist/martyrs/src/modules/orders/components/pages/OrderBackoffice.vue.cjs +1 -1
- package/dist/martyrs/src/modules/orders/components/pages/OrderBackoffice.vue.js +1 -1
- package/dist/martyrs/src/modules/orders/components/sections/FormDelivery.vue.cjs +3 -4
- package/dist/martyrs/src/modules/orders/components/sections/FormDelivery.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/orders/components/sections/FormDelivery.vue.js +3 -4
- package/dist/martyrs/src/modules/orders/components/sections/FormDelivery.vue.js.map +1 -1
- package/dist/martyrs/src/modules/orders/components/sections/FormPayment.vue.cjs +1 -1
- package/dist/martyrs/src/modules/orders/components/sections/FormPayment.vue.js +1 -1
- package/dist/martyrs/src/modules/orders/orders.client.cjs +2 -2
- package/dist/martyrs/src/modules/orders/orders.client.cjs.map +1 -1
- package/dist/martyrs/src/modules/orders/orders.client.js +2 -2
- package/dist/martyrs/src/modules/orders/orders.client.js.map +1 -1
- package/dist/martyrs/src/modules/orders/router/customers.router.cjs +1 -1
- package/dist/martyrs/src/modules/orders/router/customers.router.cjs.map +1 -1
- package/dist/martyrs/src/modules/orders/router/customers.router.js +1 -1
- package/dist/martyrs/src/modules/orders/router/customers.router.js.map +1 -1
- package/dist/martyrs/src/modules/organizations/components/blocks/CardDepartment.vue.cjs +2 -24
- package/dist/martyrs/src/modules/organizations/components/blocks/CardDepartment.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/organizations/components/blocks/CardDepartment.vue.js +5 -27
- package/dist/martyrs/src/modules/organizations/components/blocks/CardDepartment.vue.js.map +1 -1
- 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.cjs +4 -1
- package/dist/martyrs/src/modules/organizations/components/blocks/Socials.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/organizations/components/blocks/Socials.vue.js +4 -1
- package/dist/martyrs/src/modules/organizations/components/blocks/Socials.vue.js.map +1 -1
- package/dist/martyrs/src/modules/organizations/components/elements/ButtonToggleMembership.vue.cjs +3 -3
- package/dist/martyrs/src/modules/organizations/components/elements/ButtonToggleMembership.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/organizations/components/elements/ButtonToggleMembership.vue.js +3 -3
- package/dist/martyrs/src/modules/organizations/components/elements/ButtonToggleMembership.vue.js.map +1 -1
- package/dist/martyrs/src/modules/organizations/components/forms/AddExistingMembersForm.vue.cjs +195 -0
- package/dist/martyrs/src/modules/organizations/components/forms/AddExistingMembersForm.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/organizations/components/forms/AddExistingMembersForm.vue.js +195 -0
- package/dist/martyrs/src/modules/organizations/components/forms/AddExistingMembersForm.vue.js.map +1 -0
- package/dist/martyrs/src/modules/organizations/components/forms/DepartmentForm.vue.cjs +402 -0
- package/dist/martyrs/src/modules/organizations/components/forms/DepartmentForm.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/organizations/components/forms/DepartmentForm.vue.js +402 -0
- package/dist/martyrs/src/modules/organizations/components/forms/DepartmentForm.vue.js.map +1 -0
- package/dist/martyrs/src/modules/organizations/components/forms/InviteForm.vue.cjs +86 -0
- package/dist/martyrs/src/modules/organizations/components/forms/InviteForm.vue.cjs.map +1 -0
- package/dist/martyrs/src/modules/organizations/components/forms/InviteForm.vue.js +86 -0
- package/dist/martyrs/src/modules/organizations/components/forms/InviteForm.vue.js.map +1 -0
- package/dist/martyrs/src/modules/organizations/components/pages/Department.vue.cjs +10 -10
- package/dist/martyrs/src/modules/organizations/components/pages/Department.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/organizations/components/pages/Department.vue.js +11 -11
- package/dist/martyrs/src/modules/organizations/components/pages/Department.vue.js.map +1 -1
- package/dist/martyrs/src/modules/organizations/components/pages/Members.vue.cjs +279 -191
- package/dist/martyrs/src/modules/organizations/components/pages/Members.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/organizations/components/pages/Members.vue.js +285 -197
- package/dist/martyrs/src/modules/organizations/components/pages/Members.vue.js.map +1 -1
- package/dist/martyrs/src/modules/organizations/components/pages/Organization.vue.cjs +7 -7
- package/dist/martyrs/src/modules/organizations/components/pages/Organization.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/organizations/components/pages/Organization.vue.js +7 -7
- package/dist/martyrs/src/modules/organizations/components/pages/Organization.vue.js.map +1 -1
- package/dist/martyrs/src/modules/organizations/components/pages/OrganizationEdit.vue.cjs +2 -2
- package/dist/martyrs/src/modules/organizations/components/pages/OrganizationEdit.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/organizations/components/pages/OrganizationEdit.vue.js +2 -2
- package/dist/martyrs/src/modules/organizations/components/pages/OrganizationEdit.vue.js.map +1 -1
- package/dist/martyrs/src/modules/organizations/components/pages/Organizations.vue.cjs +1 -1
- package/dist/martyrs/src/modules/organizations/components/pages/Organizations.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/organizations/components/pages/Organizations.vue.js +1 -1
- package/dist/martyrs/src/modules/organizations/components/pages/Organizations.vue.js.map +1 -1
- package/dist/martyrs/src/modules/organizations/components/sections/MembersAdd.vue.cjs +1 -1
- package/dist/martyrs/src/modules/organizations/components/sections/MembersAdd.vue.js +1 -1
- package/dist/martyrs/src/modules/organizations/components/sections/Organizations.vue.cjs +3 -3
- 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 +3 -3
- package/dist/martyrs/src/modules/organizations/components/sections/Organizations.vue.js.map +1 -1
- package/dist/martyrs/src/modules/organizations/components/sections/Publics.vue.cjs +4 -4
- package/dist/martyrs/src/modules/organizations/components/sections/Publics.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/organizations/components/sections/Publics.vue.js +4 -4
- package/dist/martyrs/src/modules/organizations/components/sections/Publics.vue.js.map +1 -1
- package/dist/martyrs/src/modules/organizations/configs/navigation.organization.config.cjs +42 -41
- package/dist/martyrs/src/modules/organizations/configs/navigation.organization.config.cjs.map +1 -1
- package/dist/martyrs/src/modules/organizations/configs/navigation.organization.config.js +53 -52
- package/dist/martyrs/src/modules/organizations/configs/navigation.organization.config.js.map +1 -1
- package/dist/martyrs/src/modules/organizations/organizations.client.cjs +23 -16
- package/dist/martyrs/src/modules/organizations/organizations.client.cjs.map +1 -1
- package/dist/martyrs/src/modules/organizations/organizations.client.js +35 -28
- package/dist/martyrs/src/modules/organizations/organizations.client.js.map +1 -1
- package/dist/martyrs/src/modules/organizations/router/departments.router.cjs +0 -18
- package/dist/martyrs/src/modules/organizations/router/departments.router.cjs.map +1 -1
- package/dist/martyrs/src/modules/organizations/router/departments.router.js +0 -18
- package/dist/martyrs/src/modules/organizations/router/departments.router.js.map +1 -1
- package/dist/martyrs/src/modules/organizations/store/departments.store.cjs +6 -0
- package/dist/martyrs/src/modules/organizations/store/departments.store.cjs.map +1 -0
- package/dist/martyrs/src/modules/organizations/store/departments.store.js +6 -0
- package/dist/martyrs/src/modules/organizations/store/departments.store.js.map +1 -0
- package/dist/martyrs/src/modules/organizations/store/invites.store.cjs +6 -0
- package/dist/martyrs/src/modules/organizations/store/invites.store.cjs.map +1 -0
- package/dist/martyrs/src/modules/organizations/store/invites.store.js +6 -0
- package/dist/martyrs/src/modules/organizations/store/invites.store.js.map +1 -0
- package/dist/martyrs/src/modules/organizations/store/memberships.store.cjs +20 -0
- package/dist/martyrs/src/modules/organizations/store/memberships.store.cjs.map +1 -0
- package/dist/martyrs/src/modules/organizations/store/memberships.store.js +20 -0
- package/dist/martyrs/src/modules/organizations/store/memberships.store.js.map +1 -0
- 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/pages/CategoryEdit.vue.cjs +3 -4
- package/dist/martyrs/src/modules/products/components/pages/CategoryEdit.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/products/components/pages/CategoryEdit.vue.js +3 -4
- package/dist/martyrs/src/modules/products/components/pages/CategoryEdit.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 +2 -2
- package/dist/martyrs/src/modules/products/components/pages/Products.vue.cjs +1 -1
- package/dist/martyrs/src/modules/products/components/pages/Products.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/products/components/pages/Products.vue.js +1 -1
- package/dist/martyrs/src/modules/products/components/pages/Products.vue.js.map +1 -1
- package/dist/martyrs/src/modules/products/components/sections/EditDiscounts.vue.cjs +1 -1
- package/dist/martyrs/src/modules/products/components/sections/EditDiscounts.vue.js +1 -1
- package/dist/martyrs/src/modules/products/components/sections/EditVariants.vue.cjs +2 -2
- package/dist/martyrs/src/modules/products/components/sections/EditVariants.vue.js +2 -2
- package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttToolbar.vue.cjs +1 -1
- package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttToolbar.vue.js +1 -1
- package/dist/martyrs/src/modules/reports/components/sections/FormReport.vue.cjs +1 -1
- package/dist/martyrs/src/modules/reports/components/sections/FormReport.vue.js +1 -1
- package/dist/martyrs/src/modules/spots/components/blocks/CardSpot.vue.cjs +3 -3
- package/dist/martyrs/src/modules/spots/components/blocks/CardSpot.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/spots/components/blocks/CardSpot.vue.js +3 -3
- package/dist/martyrs/src/modules/spots/components/blocks/CardSpot.vue.js.map +1 -1
- package/dist/martyrs/src/modules/spots/components/blocks/SpotMemberModify.vue.cjs +1 -1
- package/dist/martyrs/src/modules/spots/components/blocks/SpotMemberModify.vue.js +1 -1
- package/dist/martyrs/src/modules/spots/components/layouts/Spots.vue.cjs +1 -1
- package/dist/martyrs/src/modules/spots/components/layouts/Spots.vue.js +1 -1
- package/dist/martyrs/src/modules/spots/components/pages/SpotEdit.vue.cjs +3 -3
- package/dist/martyrs/src/modules/spots/components/pages/SpotEdit.vue.js +3 -3
- package/dist/martyrs/src/modules/spots/components/pages/Spots.vue.cjs +60 -272
- package/dist/martyrs/src/modules/spots/components/pages/Spots.vue.cjs.map +1 -1
- package/dist/martyrs/src/modules/spots/components/pages/Spots.vue.js +62 -274
- package/dist/martyrs/src/modules/spots/components/pages/Spots.vue.js.map +1 -1
- package/dist/martyrs/src/modules/spots/components/sections/WorktimeEdit.vue.cjs +1 -1
- package/dist/martyrs/src/modules/spots/components/sections/WorktimeEdit.vue.js +1 -1
- package/dist/martyrs/src/modules/wallet/views/components/blocks/CryptoDeposit.vue.cjs +1 -1
- package/dist/martyrs/src/modules/wallet/views/components/blocks/CryptoDeposit.vue.js +1 -1
- package/dist/martyrs/src/modules/wallet/views/components/pages/Wallet.vue.cjs +4 -4
- package/dist/martyrs/src/modules/wallet/views/components/pages/Wallet.vue.js +4 -4
- package/dist/martyrs.cjs.js +1 -1
- package/dist/martyrs.css +1 -1
- package/dist/martyrs.es.js +1 -1
- package/dist/music.server.cjs +9 -9
- package/dist/music.server.js +9 -9
- package/dist/notifications.server.cjs +0 -24
- package/dist/notifications.server.js +0 -24
- package/dist/orders.server.cjs +3 -6
- package/dist/orders.server.js +3 -6
- package/dist/organizations.server.cjs +119 -43
- package/dist/organizations.server.js +119 -43
- package/dist/products.server.cjs +5 -5
- package/dist/products.server.js +5 -5
- package/dist/rents.server.cjs +3 -3
- package/dist/rents.server.js +3 -3
- package/dist/style.css +16 -17
- package/dist/wallet.server.cjs +2 -2
- package/dist/wallet.server.js +2 -2
- package/dist/{web-B5wZTKbK.cjs → web-B0cfxzgu.cjs} +1 -1
- package/dist/{web-520xCgXy.js → web-DVR8m2fm.js} +1 -1
- package/package.json +1 -1
- package/src/builder/modes/ssr.rspack.dev.js +20 -12
- package/src/builder/rspack/rspack.config.base.js +16 -15
- package/src/components/Button/Button.vue +1 -1
- package/src/components/Feed/Feed.old.vue +0 -1
- package/src/components/Feed/Feed.vue +1 -31
- package/src/components/Loader/Loader.vue +1 -1
- package/src/modules/auth/FIXES.md +61 -0
- package/src/modules/auth/PROMT.md +33 -0
- package/src/modules/auth/auth.server.js +1 -0
- package/src/modules/auth/views/components/blocks/CardUser.vue +2 -2
- package/src/modules/auth/views/components/layouts/Auth.vue +1 -1
- package/src/modules/auth/views/components/pages/Invite.vue +2 -2
- package/src/modules/auth/views/components/pages/Profile.vue +33 -48
- package/src/modules/auth/views/components/sections/SliderFeatures.vue +5 -7
- package/src/modules/auth/views/store/auth.js +16 -1
- package/src/modules/auth//320/220/320/240/320/245/320/230/320/242/320/225/320/232/320/242/320/243/320/240/320/220.md +445 -0
- package/src/modules/backoffice/components/partials/Sidebar.vue +6 -0
- package/src/modules/chats/CLAUDE.md +137 -0
- package/src/modules/chats/components/blocks/ChatMessage.vue +12 -0
- package/src/modules/chats/components/sections/ChatWindow.vue +84 -2
- package/src/modules/chats/controllers/chats.controller.js +187 -0
- package/src/modules/chats/models/chat.model.js +21 -0
- package/src/modules/chats/routes/chats.routes.js +46 -0
- package/src/modules/chats/store/chat.store.js +67 -0
- package/src/modules/community/components/layouts/Community.vue +2 -2
- package/src/modules/community/components/pages/Posts.vue +3 -328
- package/src/modules/events/components/pages/EditEventTickets.vue +1 -1
- package/src/modules/events/components/pages/Events.vue +2 -2
- package/src/modules/globals/controllers/classes/globals.cache.js +64 -55
- package/src/modules/globals/controllers/classes/globals.logger.js +40 -4
- package/src/modules/globals/controllers/classes/globals.observer.js +54 -4
- package/src/modules/globals/views/components/partials/Header.vue +1 -1
- package/src/modules/globals/views/components/partials/Sidebar.vue +17 -13
- package/src/modules/globals/views/mixins/mixins.js +7 -0
- package/src/modules/inventory/CLAUDE.md +330 -0
- package/src/modules/inventory/PROMT.md +25 -0
- package/src/modules/inventory/components/forms/AdjustmentForm.vue +53 -36
- package/src/modules/inventory/components/forms/ColumnSettingsMenu.vue +11 -6
- package/src/modules/inventory/components/forms/HistoryView.vue +21 -9
- package/src/modules/inventory/components/forms/StockAlertsForm.vue +33 -22
- package/src/modules/inventory/components/pages/Inventory.vue +40 -40
- package/src/modules/inventory/components/pages/InventoryEdit.vue +1 -1
- package/src/modules/inventory/docs/01-intro.md +126 -0
- package/src/modules/inventory/docs/02-architecture.md +266 -0
- package/src/modules/inventory/docs/03-components-and-relationships.md +338 -0
- package/src/modules/inventory/docs/04-business-logic-and-algorithms.md +376 -0
- package/src/modules/inventory/docs/05-api-specification.md +356 -0
- package/src/modules/inventory/docs/06-access-control.md +320 -0
- package/src/modules/inventory/inventory.server.js +6 -2
- package/src/modules/inventory/{services → middlewares}/inventory.verifier.js +5 -16
- package/src/modules/inventory/models/stock.availability.model.js +20 -7
- package/src/modules/inventory/routes/inventory.routes.js +14 -17
- package/src/modules/inventory/services/adjustment.service.js +137 -0
- package/src/modules/inventory/services/audit.service.js +160 -0
- package/src/modules/inventory/services/availability.service.js +323 -0
- package/src/modules/inventory/services/inventory.helpers.old.js +217 -0
- package/src/modules/inventory/store/{ inventory.store.js → inventory.store.js} +0 -14
- package/src/modules/inventory/workers/inventory.availability.worker.js +29 -30
- package/src/modules/marketplace/views/components/layouts/Marketplace.vue +160 -8
- package/src/modules/notifications/controllers/notifications.controller.js +0 -6
- package/src/modules/notifications/services/notification.service.js +1 -17
- package/src/modules/notifications/services/web-push.service.js +0 -2
- package/src/modules/orders/components/blocks/CardOrderBackoffice.vue +2 -2
- package/src/modules/orders/components/blocks/CardOrderVar1.vue +1 -1
- package/src/modules/orders/controllers/orders.controller.js +2 -4
- package/src/modules/orders/orders.client.js +2 -2
- package/src/modules/orders/router/customers.router.js +1 -1
- package/src/modules/organizations/CLAUDE.md +259 -0
- package/src/modules/organizations/components/blocks/CardDepartment.vue +1 -22
- package/src/modules/organizations/components/blocks/Socials.vue +1 -1
- package/src/modules/organizations/components/elements/ButtonToggleMembership.vue +3 -3
- package/src/modules/organizations/components/forms/AddExistingMembersForm.vue +191 -0
- package/src/modules/organizations/components/forms/DepartmentForm.vue +390 -0
- package/src/modules/organizations/components/forms/InviteForm.vue +81 -0
- package/src/modules/organizations/components/pages/Department.vue +10 -10
- package/src/modules/organizations/components/pages/DepartmentEdit.vue +8 -8
- package/src/modules/organizations/components/pages/Members.vue +265 -171
- package/src/modules/organizations/components/pages/Organization.new.vue +172 -183
- package/src/modules/organizations/components/pages/Organization.vue +6 -6
- package/src/modules/organizations/components/pages/OrganizationEdit.vue +1 -1
- package/src/modules/organizations/components/pages/Organizations.vue +1 -1
- package/src/modules/organizations/components/sections/Organizations.vue +2 -2
- package/src/modules/organizations/components/sections/Publics.vue +4 -4
- package/src/modules/organizations/configs/navigation.organization.config.js +40 -39
- package/src/modules/organizations/controllers/departments.controller.js +53 -34
- package/src/modules/organizations/controllers/invites.controller.js +44 -5
- package/src/modules/organizations/controllers/memberships.controller.js +43 -4
- package/src/modules/organizations/organizations.client.js +24 -15
- package/src/modules/organizations/router/departments.router.js +0 -18
- package/src/modules/organizations/routes/departments.routes.js +6 -8
- package/src/modules/organizations/routes/invites.routes.js +6 -4
- package/src/modules/organizations/routes/memberships.routes.js +6 -5
- package/src/modules/organizations/routes/organizations.routes.js +1 -1
- package/src/modules/organizations/store/departments.store.js +5 -0
- package/src/modules/organizations/store/invites.store.js +5 -0
- package/src/modules/organizations/store/memberships.store.js +23 -0
- package/src/modules/products/components/pages/Products.vue +0 -1
- package/src/modules/spots/components/blocks/CardSpot.vue +1 -1
- package/src/modules/spots/components/pages/Spots.vue +3 -203
- package/src/styles/base/all.scss +0 -15
- package/src/styles/responsive.scss +1 -31
- package/src/styles/typography.scss +20 -5
- package/dist/main-CSzPfQYR.cjs +0 -11
- package/dist/martyrs/src/components/Address/Address.vue2.cjs.map +0 -1
- package/dist/martyrs/src/components/Chips/Chips.vue.cjs.map +0 -1
- package/dist/martyrs/src/components/Chips/Chips.vue.js.map +0 -1
- package/dist/martyrs/src/components/Dropdown/Dropdown.vue.js.map +0 -1
- package/dist/martyrs/src/components/LocationMarker/LocationMarker.vue2.cjs.map +0 -1
- package/dist/martyrs/src/components/Select/Select.vue2.cjs.map +0 -1
- package/dist/martyrs/src/modules/globals/views/components/blocks/BlockFilter.vue.cjs +0 -76
- package/dist/martyrs/src/modules/globals/views/components/blocks/BlockFilter.vue.cjs.map +0 -1
- package/dist/martyrs/src/modules/globals/views/components/blocks/BlockFilter.vue.js +0 -76
- package/dist/martyrs/src/modules/globals/views/components/blocks/BlockFilter.vue.js.map +0 -1
- package/dist/martyrs/src/modules/inventory/store/ inventory.store.cjs.map +0 -1
- package/dist/martyrs/src/modules/inventory/store/ inventory.store.js.map +0 -1
- package/dist/martyrs/src/modules/organizations/components/pages/DepartmentEdit.vue.cjs +0 -280
- package/dist/martyrs/src/modules/organizations/components/pages/DepartmentEdit.vue.cjs.map +0 -1
- package/dist/martyrs/src/modules/organizations/components/pages/DepartmentEdit.vue.js +0 -280
- package/dist/martyrs/src/modules/organizations/components/pages/DepartmentEdit.vue.js.map +0 -1
- package/dist/martyrs/src/modules/organizations/store/departments.cjs +0 -121
- package/dist/martyrs/src/modules/organizations/store/departments.cjs.map +0 -1
- package/dist/martyrs/src/modules/organizations/store/departments.js +0 -121
- package/dist/martyrs/src/modules/organizations/store/departments.js.map +0 -1
- package/dist/martyrs/src/modules/organizations/store/invites.cjs +0 -64
- package/dist/martyrs/src/modules/organizations/store/invites.cjs.map +0 -1
- package/dist/martyrs/src/modules/organizations/store/invites.js +0 -64
- package/dist/martyrs/src/modules/organizations/store/invites.js.map +0 -1
- package/dist/martyrs/src/modules/organizations/store/memberships.cjs +0 -87
- package/dist/martyrs/src/modules/organizations/store/memberships.cjs.map +0 -1
- package/dist/martyrs/src/modules/organizations/store/memberships.js +0 -87
- package/dist/martyrs/src/modules/organizations/store/memberships.js.map +0 -1
- package/src/modules/globals/controllers/classes/globals.websocket.ws.js +0 -102
- package/src/modules/globals/views/components/blocks/BlockFilter.vue +0 -60
- package/src/modules/inventory/docs/README.md +0 -291
- package/src/modules/inventory/models/stock.balance.model.js +0 -43
- package/src/modules/inventory/services/inventory.crud.js +0 -710
- package/src/modules/inventory/tests/inventory.test.js +0 -281
- package/src/modules/organizations/store/departments.js +0 -137
- package/src/modules/organizations/store/invites.js +0 -76
- package/src/modules/organizations/store/memberships.js +0 -110
|
@@ -1,16 +1,15 @@
|
|
|
1
1
|
import StockAdjustmentModel from './models/stock.adjustment.model.js';
|
|
2
|
-
import StockBalanceModel from './models/stock.balance.model.js';
|
|
3
2
|
import StockAvailabilityModel from './models/stock.availability.model.js';
|
|
4
3
|
import StockAuditModel from './models/stock.audit.model.js';
|
|
5
4
|
import StockAlertModel from './models/stock.alerts.model.js';
|
|
6
5
|
|
|
7
6
|
import inventoryRoutes from './routes/inventory.routes.js';
|
|
8
7
|
import inventoryPolicies from './policies/inventory.policies.js';
|
|
8
|
+
import availabilityServiceFactory from './services/availability.service.js';
|
|
9
9
|
|
|
10
10
|
function initializeInventory(app, db, origins, publicPath) {
|
|
11
11
|
// Регистрация моделей
|
|
12
12
|
db.stockAdjustment = StockAdjustmentModel(db);
|
|
13
|
-
db.stockBalance = StockBalanceModel(db);
|
|
14
13
|
db.stockAvailability = StockAvailabilityModel(db);
|
|
15
14
|
db.stockAudit = StockAuditModel(db);
|
|
16
15
|
db.stockAlert = StockAlertModel(db);
|
|
@@ -19,6 +18,11 @@ function initializeInventory(app, db, origins, publicPath) {
|
|
|
19
18
|
if (app) {
|
|
20
19
|
inventoryRoutes(app, db, origins, publicPath);
|
|
21
20
|
inventoryPolicies(db);
|
|
21
|
+
|
|
22
|
+
// Инициализация availability service с change streams
|
|
23
|
+
const availabilityService = availabilityServiceFactory(db);
|
|
24
|
+
|
|
25
|
+
availabilityService.initChangeStreams();
|
|
22
26
|
}
|
|
23
27
|
}
|
|
24
28
|
|
|
@@ -34,8 +34,8 @@ export default function(db) {
|
|
|
34
34
|
comment: { rule: 'optional', validator: Validator.schema().string() }
|
|
35
35
|
};
|
|
36
36
|
|
|
37
|
-
//
|
|
38
|
-
const
|
|
37
|
+
// Availability & Inventory query verifiers
|
|
38
|
+
const queryConfig = {
|
|
39
39
|
product: { rule: 'optional', validator: Validator.schema().string() },
|
|
40
40
|
storage: { rule: 'optional', validator: Validator.schema().string() },
|
|
41
41
|
skip: { rule: 'optional', validator: Validator.schema().integer().min(0), default: 0 },
|
|
@@ -65,7 +65,7 @@ export default function(db) {
|
|
|
65
65
|
|
|
66
66
|
const adjustmentQueryVerifier = new Verifier(adjustmentQueryConfig);
|
|
67
67
|
const adjustmentBodyVerifier = new Verifier(adjustmentBodyConfig);
|
|
68
|
-
const
|
|
68
|
+
const queryVerifier = new Verifier(queryConfig);
|
|
69
69
|
const inventoryBodyVerifier = new Verifier(inventoryBodyConfig);
|
|
70
70
|
|
|
71
71
|
return {
|
|
@@ -85,19 +85,8 @@ export default function(db) {
|
|
|
85
85
|
req.verifiedBody = verification.verifiedData;
|
|
86
86
|
next();
|
|
87
87
|
},
|
|
88
|
-
verifyBalanceQuery: (req, res, next) => {
|
|
89
|
-
const verification = balanceQueryVerifier.verify(req.query);
|
|
90
|
-
if (!verification.isValid) {
|
|
91
|
-
return res.status(400).json({ errors: verification.verificationErrors });
|
|
92
|
-
}
|
|
93
|
-
// Преобразуем числовые поля
|
|
94
|
-
verification.verifiedData.skip = parseInt(verification.verifiedData.skip) || 0;
|
|
95
|
-
verification.verifiedData.limit = parseInt(verification.verifiedData.limit) || 50;
|
|
96
|
-
req.verifiedQuery = verification.verifiedData;
|
|
97
|
-
next();
|
|
98
|
-
},
|
|
99
88
|
verifyAvailabilityQuery: (req, res, next) => {
|
|
100
|
-
const verification =
|
|
89
|
+
const verification = queryVerifier.verify(req.query);
|
|
101
90
|
if (!verification.isValid) {
|
|
102
91
|
return res.status(400).json({ errors: verification.verificationErrors });
|
|
103
92
|
}
|
|
@@ -108,7 +97,7 @@ export default function(db) {
|
|
|
108
97
|
next();
|
|
109
98
|
},
|
|
110
99
|
verifyInventoryQuery: (req, res, next) => {
|
|
111
|
-
const verification =
|
|
100
|
+
const verification = queryVerifier.verify(req.query);
|
|
112
101
|
if (!verification.isValid) {
|
|
113
102
|
return res.status(400).json({ errors: verification.verificationErrors });
|
|
114
103
|
}
|
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
import applyOwnershipSchema from '@martyrs/src/modules/globals/models/schemas/ownership.schema.js';
|
|
2
|
+
|
|
1
3
|
export default db => {
|
|
2
4
|
const StockAvailabilitySchema = new db.mongoose.Schema({
|
|
3
5
|
product: {
|
|
@@ -8,18 +10,18 @@ export default db => {
|
|
|
8
10
|
variant: {
|
|
9
11
|
type: db.mongoose.Schema.Types.ObjectId,
|
|
10
12
|
ref: 'Variant',
|
|
11
|
-
required: true,
|
|
12
13
|
},
|
|
13
14
|
storage: {
|
|
14
15
|
type: db.mongoose.Schema.Types.ObjectId,
|
|
15
16
|
ref: 'Spot',
|
|
16
17
|
required: true,
|
|
17
18
|
},
|
|
18
|
-
//
|
|
19
|
+
// Physical stock quantity (was in StockBalance)
|
|
19
20
|
quantity: {
|
|
20
21
|
type: Number,
|
|
21
22
|
default: 0,
|
|
22
23
|
},
|
|
24
|
+
// Computed availability for sale
|
|
23
25
|
available: {
|
|
24
26
|
type: Number,
|
|
25
27
|
default: 0,
|
|
@@ -37,17 +39,28 @@ export default db => {
|
|
|
37
39
|
required: Number,
|
|
38
40
|
available: Number,
|
|
39
41
|
}],
|
|
42
|
+
calculatedAt: {
|
|
43
|
+
type: Date,
|
|
44
|
+
default: Date.now,
|
|
45
|
+
}
|
|
40
46
|
}, {
|
|
41
47
|
timestamps: {
|
|
42
48
|
currentTime: () => Date.now(),
|
|
43
49
|
},
|
|
44
50
|
});
|
|
45
51
|
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
52
|
+
applyOwnershipSchema(StockAvailabilitySchema, db);
|
|
53
|
+
|
|
54
|
+
// Add proper composite index for lookups (from StockBalance)
|
|
55
|
+
StockAvailabilitySchema.index({product: 1, variant: 1, storage: 1}, {unique: true});
|
|
56
|
+
|
|
57
|
+
// Add individual indexes for common lookups (from StockBalance)
|
|
58
|
+
StockAvailabilitySchema.index({updatedAt: -1});
|
|
59
|
+
StockAvailabilitySchema.index({ storage: 1, variant: 1 });
|
|
60
|
+
StockAvailabilitySchema.index({ storage: 1, product: 1 });
|
|
61
|
+
StockAvailabilitySchema.index({ quantity: -1 });
|
|
62
|
+
|
|
63
|
+
// Original availability indexes
|
|
51
64
|
StockAvailabilitySchema.index({ storage: 1 });
|
|
52
65
|
StockAvailabilitySchema.index({ available: -1 });
|
|
53
66
|
|
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
import jwtFactory from '@martyrs/src/modules/auth/controllers/middlewares/authJwt.js';
|
|
2
2
|
import globalsabac from '@martyrs/src/modules/globals/controllers/classes/globals.abac.js';
|
|
3
|
-
import
|
|
4
|
-
import
|
|
3
|
+
import adjustmentServiceFactory from '../services/adjustment.service.js';
|
|
4
|
+
import availabilityServiceFactory from '../services/availability.service.js';
|
|
5
|
+
import auditServiceFactory from '../services/audit.service.js';
|
|
6
|
+
import verifierFactory from '../middlewares/inventory.verifier.js';
|
|
5
7
|
import setupStockAlertsRoutes from './stock.alerts.routes.js';
|
|
6
8
|
|
|
7
9
|
const { getInstance } = globalsabac;
|
|
@@ -10,54 +12,49 @@ export default function(app, db) {
|
|
|
10
12
|
const jwt = jwtFactory(db);
|
|
11
13
|
const verifier = verifierFactory(db);
|
|
12
14
|
const abac = getInstance(db);
|
|
13
|
-
const
|
|
15
|
+
const adjustmentService = adjustmentServiceFactory(db);
|
|
16
|
+
const availabilityService = availabilityServiceFactory(db);
|
|
17
|
+
const auditService = auditServiceFactory(db);
|
|
14
18
|
|
|
15
19
|
// StockAdjustment routes
|
|
16
20
|
app.get('/api/inventory/adjustments',
|
|
17
21
|
jwt.verifyToken(true),
|
|
18
22
|
verifier.verifyAdjustmentQuery,
|
|
19
|
-
|
|
23
|
+
adjustmentService.read
|
|
20
24
|
);
|
|
21
25
|
|
|
22
26
|
app.post('/api/inventory/adjustments/create',
|
|
23
27
|
jwt.verifyToken(),
|
|
24
28
|
verifier.verifyAdjustmentBody,
|
|
25
29
|
abac.middleware('stockAdjustment', 'create'),
|
|
26
|
-
|
|
27
|
-
);
|
|
28
|
-
|
|
29
|
-
// StockBalance routes
|
|
30
|
-
app.get('/api/inventory/balance',
|
|
31
|
-
jwt.verifyToken(true),
|
|
32
|
-
verifier.verifyBalanceQuery,
|
|
33
|
-
controller.balance.read
|
|
30
|
+
adjustmentService.create
|
|
34
31
|
);
|
|
35
32
|
|
|
36
33
|
// StockAvailability routes
|
|
37
34
|
app.get('/api/inventory/availability',
|
|
38
35
|
verifier.verifyAvailabilityQuery,
|
|
39
|
-
|
|
36
|
+
availabilityService.read
|
|
40
37
|
);
|
|
41
38
|
|
|
42
|
-
//
|
|
39
|
+
// StockAudit routes
|
|
43
40
|
app.get('/api/inventory/audits',
|
|
44
41
|
jwt.verifyToken(),
|
|
45
42
|
verifier.verifyInventoryQuery,
|
|
46
|
-
|
|
43
|
+
auditService.read
|
|
47
44
|
);
|
|
48
45
|
|
|
49
46
|
app.post('/api/inventory/audits/create',
|
|
50
47
|
jwt.verifyToken(),
|
|
51
48
|
verifier.verifyInventoryBody,
|
|
52
49
|
abac.middleware('stockAudit', 'create'),
|
|
53
|
-
|
|
50
|
+
auditService.create
|
|
54
51
|
);
|
|
55
52
|
|
|
56
53
|
app.post('/api/inventory/audits/complete',
|
|
57
54
|
jwt.verifyToken(),
|
|
58
55
|
verifier.verifyInventoryComplete,
|
|
59
56
|
abac.middleware('stockAudit', 'edit'),
|
|
60
|
-
|
|
57
|
+
auditService.complete
|
|
61
58
|
);
|
|
62
59
|
|
|
63
60
|
// Initialize stock alerts routes
|
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
import queryProcessor from '@martyrs/src/modules/globals/controllers/utils/queryProcessor.js';
|
|
2
|
+
import Cache from '@martyrs/src/modules/globals/controllers/classes/globals.cache.js';
|
|
3
|
+
import Logger from '@martyrs/src/modules/globals/controllers/classes/globals.logger.js';
|
|
4
|
+
import Observer from '@martyrs/src/modules/globals/controllers/classes/globals.observer.js';
|
|
5
|
+
import availabilityServiceFactory from './availability.service.js';
|
|
6
|
+
|
|
7
|
+
const adjustmentServiceFactory = db => {
|
|
8
|
+
const cache = new Cache({ ttlSeconds: 300 });
|
|
9
|
+
const logger = new Logger(db);
|
|
10
|
+
const observer = new Observer();
|
|
11
|
+
const availabilityService = availabilityServiceFactory(db);
|
|
12
|
+
|
|
13
|
+
// Update quantity in stockAvailability - local function
|
|
14
|
+
const updateStockQuantity = async (product, variant, storage, quantity, owner, creator, session) => {
|
|
15
|
+
return await db.stockAvailability.findOneAndUpdate(
|
|
16
|
+
{ product, variant, storage },
|
|
17
|
+
{
|
|
18
|
+
$inc: { quantity },
|
|
19
|
+
$setOnInsert: {
|
|
20
|
+
owner,
|
|
21
|
+
creator,
|
|
22
|
+
available: 0,
|
|
23
|
+
constraints: []
|
|
24
|
+
}
|
|
25
|
+
},
|
|
26
|
+
{ upsert: true, new: true, session }
|
|
27
|
+
);
|
|
28
|
+
};
|
|
29
|
+
|
|
30
|
+
return {
|
|
31
|
+
async read(req, res) {
|
|
32
|
+
try {
|
|
33
|
+
const cacheKey = JSON.stringify({ type: 'adjustments', ...req.verifiedQuery });
|
|
34
|
+
let data = await cache.get(cacheKey);
|
|
35
|
+
|
|
36
|
+
if (!data) {
|
|
37
|
+
const stages = [
|
|
38
|
+
...queryProcessor.getBasicOptions(req.verifiedQuery),
|
|
39
|
+
{
|
|
40
|
+
$lookup: {
|
|
41
|
+
from: 'products',
|
|
42
|
+
let: { pid: '$product' },
|
|
43
|
+
pipeline: [
|
|
44
|
+
{ $match: { $expr: { $eq: ['$_id', '$$pid'] } } },
|
|
45
|
+
{
|
|
46
|
+
$project: {
|
|
47
|
+
name: 1,
|
|
48
|
+
sku: 1,
|
|
49
|
+
unit: 1
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
],
|
|
53
|
+
as: 'productData'
|
|
54
|
+
}
|
|
55
|
+
},
|
|
56
|
+
{
|
|
57
|
+
$unwind: {
|
|
58
|
+
path: '$productData',
|
|
59
|
+
preserveNullAndEmptyArrays: true
|
|
60
|
+
}
|
|
61
|
+
},
|
|
62
|
+
queryProcessor.getCreatorUserLookupStage(),
|
|
63
|
+
queryProcessor.getAddFieldsCreatorOwnerStage(),
|
|
64
|
+
...queryProcessor.getSortingOptions('createdAt', 'desc'),
|
|
65
|
+
...queryProcessor.getPaginationOptions(req.verifiedQuery.skip, req.verifiedQuery.limit)
|
|
66
|
+
];
|
|
67
|
+
|
|
68
|
+
data = await db.stockAdjustment.aggregate(stages).exec();
|
|
69
|
+
await cache.setWithTags(cacheKey, data, ['adjustments']);
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
res.json(data);
|
|
73
|
+
} catch (error) {
|
|
74
|
+
logger.error('Error reading adjustments', error);
|
|
75
|
+
res.status(500).json({ message: error.message });
|
|
76
|
+
}
|
|
77
|
+
},
|
|
78
|
+
|
|
79
|
+
async create(req, res) {
|
|
80
|
+
const session = await db.mongoose.startSession();
|
|
81
|
+
session.startTransaction();
|
|
82
|
+
|
|
83
|
+
try {
|
|
84
|
+
const adjustmentData = {
|
|
85
|
+
...req.verifiedBody,
|
|
86
|
+
creator: req.verifiedBody.creator || { type: 'user', target: req.userId },
|
|
87
|
+
owner: req.verifiedBody.owner
|
|
88
|
+
};
|
|
89
|
+
|
|
90
|
+
const [adjustment] = await db.stockAdjustment.create([adjustmentData], { session });
|
|
91
|
+
|
|
92
|
+
const availability = await updateStockQuantity(
|
|
93
|
+
adjustmentData.product,
|
|
94
|
+
adjustmentData.variant,
|
|
95
|
+
adjustmentData.storage,
|
|
96
|
+
adjustmentData.quantity,
|
|
97
|
+
adjustmentData.owner,
|
|
98
|
+
adjustmentData.creator,
|
|
99
|
+
session
|
|
100
|
+
);
|
|
101
|
+
|
|
102
|
+
const affectedVariants = await availabilityService.collectAffectedVariants(
|
|
103
|
+
[adjustmentData.product],
|
|
104
|
+
adjustmentData.variant ? [adjustmentData.variant] : [],
|
|
105
|
+
session
|
|
106
|
+
);
|
|
107
|
+
|
|
108
|
+
if (affectedVariants.length) {
|
|
109
|
+
await availabilityService.recalculateAvailability(affectedVariants, adjustmentData.storage, session);
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
await session.commitTransaction();
|
|
113
|
+
|
|
114
|
+
availabilityService.invalidateCache(['adjustments', 'availability']);
|
|
115
|
+
|
|
116
|
+
setImmediate(() => {
|
|
117
|
+
observer.notify('stock.adjusted', {
|
|
118
|
+
adjustment,
|
|
119
|
+
availability,
|
|
120
|
+
affectedVariants
|
|
121
|
+
});
|
|
122
|
+
});
|
|
123
|
+
|
|
124
|
+
res.status(201).json(adjustment);
|
|
125
|
+
} catch (error) {
|
|
126
|
+
console.log(error)
|
|
127
|
+
await session.abortTransaction();
|
|
128
|
+
logger.error('Error creating adjustment', error);
|
|
129
|
+
res.status(500).json({ message: error.message });
|
|
130
|
+
} finally {
|
|
131
|
+
session.endSession();
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
};
|
|
135
|
+
};
|
|
136
|
+
|
|
137
|
+
export default adjustmentServiceFactory;
|
|
@@ -0,0 +1,160 @@
|
|
|
1
|
+
import queryProcessor from '@martyrs/src/modules/globals/controllers/utils/queryProcessor.js';
|
|
2
|
+
import Cache from '@martyrs/src/modules/globals/controllers/classes/globals.cache.js';
|
|
3
|
+
import Logger from '@martyrs/src/modules/globals/controllers/classes/globals.logger.js';
|
|
4
|
+
import Observer from '@martyrs/src/modules/globals/controllers/classes/globals.observer.js';
|
|
5
|
+
import availabilityServiceFactory from './availability.service.js';
|
|
6
|
+
|
|
7
|
+
const auditServiceFactory = db => {
|
|
8
|
+
const cache = new Cache({ ttlSeconds: 300 });
|
|
9
|
+
const logger = new Logger(db);
|
|
10
|
+
const observer = new Observer();
|
|
11
|
+
const availabilityService = availabilityServiceFactory(db);
|
|
12
|
+
|
|
13
|
+
// Process inventory positions
|
|
14
|
+
async function processInventoryPositions(audit, session) {
|
|
15
|
+
// Create adjustments
|
|
16
|
+
await Promise.all(
|
|
17
|
+
audit.positions.map(position =>
|
|
18
|
+
db.stockAdjustment.create([{
|
|
19
|
+
product: position.product,
|
|
20
|
+
variant: position.variant,
|
|
21
|
+
storage: audit.storage,
|
|
22
|
+
source: { type: 'Inventory', target: audit._id },
|
|
23
|
+
reason: position.reason || 'custom',
|
|
24
|
+
comment: position.comment,
|
|
25
|
+
quantity: position.quantity,
|
|
26
|
+
cost: position.cost,
|
|
27
|
+
creator: audit.creator,
|
|
28
|
+
owner: audit.owner
|
|
29
|
+
}], { session })
|
|
30
|
+
)
|
|
31
|
+
);
|
|
32
|
+
|
|
33
|
+
// Update quantities
|
|
34
|
+
await db.stockAvailability.bulkWrite(
|
|
35
|
+
audit.positions.map(p => ({
|
|
36
|
+
updateOne: {
|
|
37
|
+
filter: {
|
|
38
|
+
product: p.product,
|
|
39
|
+
variant: p.variant || null,
|
|
40
|
+
storage: audit.storage
|
|
41
|
+
},
|
|
42
|
+
update: {
|
|
43
|
+
$inc: { quantity: p.quantity },
|
|
44
|
+
$setOnInsert: {
|
|
45
|
+
owner: audit.owner,
|
|
46
|
+
creator: audit.creator,
|
|
47
|
+
available: 0,
|
|
48
|
+
constraints: []
|
|
49
|
+
}
|
|
50
|
+
},
|
|
51
|
+
upsert: true
|
|
52
|
+
}
|
|
53
|
+
})),
|
|
54
|
+
{ session }
|
|
55
|
+
);
|
|
56
|
+
|
|
57
|
+
// Collect affected items
|
|
58
|
+
const products = audit.positions.map(p => p.product);
|
|
59
|
+
const variants = audit.positions.filter(p => p.variant).map(p => p.variant);
|
|
60
|
+
|
|
61
|
+
return await availabilityService.collectAffectedVariants(products, variants, session);
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
return {
|
|
65
|
+
async read(req, res) {
|
|
66
|
+
try {
|
|
67
|
+
const stages = [
|
|
68
|
+
...queryProcessor.getBasicOptions(req.verifiedQuery),
|
|
69
|
+
queryProcessor.getCreatorUserLookupStage(),
|
|
70
|
+
queryProcessor.getAddFieldsCreatorOwnerStage(),
|
|
71
|
+
...queryProcessor.getSortingOptions('createdAt', 'desc'),
|
|
72
|
+
...queryProcessor.getPaginationOptions(req.verifiedQuery.skip, req.verifiedQuery.limit)
|
|
73
|
+
];
|
|
74
|
+
|
|
75
|
+
const data = await db.stockAudit.aggregate(stages).exec();
|
|
76
|
+
res.json(data);
|
|
77
|
+
} catch (error) {
|
|
78
|
+
logger.error('Error reading inventories', error);
|
|
79
|
+
res.status(500).json({ message: error.message });
|
|
80
|
+
}
|
|
81
|
+
},
|
|
82
|
+
|
|
83
|
+
async create(req, res) {
|
|
84
|
+
const session = await db.mongoose.startSession();
|
|
85
|
+
session.startTransaction();
|
|
86
|
+
|
|
87
|
+
try {
|
|
88
|
+
const inventoryData = {
|
|
89
|
+
...req.verifiedBody,
|
|
90
|
+
creator: { type: 'user', target: req.userId },
|
|
91
|
+
owner: req.verifiedBody.owner
|
|
92
|
+
};
|
|
93
|
+
|
|
94
|
+
const audit = await db.stockAudit.create([inventoryData], { session });
|
|
95
|
+
|
|
96
|
+
if (req.verifiedBody.status === 'published') {
|
|
97
|
+
const affectedVariants = await processInventoryPositions(audit[0], session);
|
|
98
|
+
|
|
99
|
+
if (affectedVariants.length) {
|
|
100
|
+
await availabilityService.recalculateAvailability(affectedVariants, audit[0].storage, session);
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
await session.commitTransaction();
|
|
105
|
+
availabilityService.invalidateCache(['inventories', 'availability']);
|
|
106
|
+
|
|
107
|
+
res.status(201).json(audit[0]);
|
|
108
|
+
} catch (error) {
|
|
109
|
+
await session.abortTransaction();
|
|
110
|
+
logger.error('Error creating inventory', error);
|
|
111
|
+
res.status(500).json({ message: error.message });
|
|
112
|
+
} finally {
|
|
113
|
+
session.endSession();
|
|
114
|
+
}
|
|
115
|
+
},
|
|
116
|
+
|
|
117
|
+
async complete(req, res) {
|
|
118
|
+
const session = await db.mongoose.startSession();
|
|
119
|
+
session.startTransaction();
|
|
120
|
+
|
|
121
|
+
try {
|
|
122
|
+
const inventory = await db.stockAudit.findById(req.verifiedBody._id).session(session);
|
|
123
|
+
|
|
124
|
+
if (!inventory || inventory.status !== 'draft') {
|
|
125
|
+
throw new Error('Invalid inventory status');
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
const affectedVariants = await processInventoryPositions(inventory, session);
|
|
129
|
+
|
|
130
|
+
if (affectedVariants.length) {
|
|
131
|
+
await availabilityService.recalculateAvailability(affectedVariants, inventory.storage, session);
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
inventory.status = 'published';
|
|
135
|
+
await inventory.save({ session });
|
|
136
|
+
|
|
137
|
+
await session.commitTransaction();
|
|
138
|
+
|
|
139
|
+
availabilityService.invalidateCache(['adjustments', 'availability', 'inventories']);
|
|
140
|
+
|
|
141
|
+
setImmediate(() => {
|
|
142
|
+
observer.notify('inventory.completed', {
|
|
143
|
+
inventory,
|
|
144
|
+
affectedVariants
|
|
145
|
+
});
|
|
146
|
+
});
|
|
147
|
+
|
|
148
|
+
res.json(inventory);
|
|
149
|
+
} catch (error) {
|
|
150
|
+
await session.abortTransaction();
|
|
151
|
+
logger.error('Error completing inventory', error);
|
|
152
|
+
res.status(500).json({ message: error.message });
|
|
153
|
+
} finally {
|
|
154
|
+
session.endSession();
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
};
|
|
158
|
+
};
|
|
159
|
+
|
|
160
|
+
export default auditServiceFactory;
|