@ozdao/prometheus-framework 0.1.36 → 0.1.38
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/BackofficeGallery-568b55bb.js +1 -0
- package/dist/BackofficeGallery-b4105137.mjs +306 -0
- package/dist/BlockTags-8cddaef7.js +1 -0
- package/dist/BlockTags-ee310572.mjs +853 -0
- package/dist/Breadcrumbs.vue_vue_type_style_index_0_lang-0ea8fbf8.js +1 -0
- package/dist/Breadcrumbs.vue_vue_type_style_index_0_lang-4ed993c7.mjs +1 -0
- package/dist/Button-7643c9aa.js +1 -0
- package/dist/Button-9e1a9284.mjs +226 -0
- package/dist/ButtonToggleMembership-15f149cb.js +1 -0
- package/dist/ButtonToggleMembership-3bb9139e.mjs +90 -0
- package/dist/CardBlogpost-38016b80.mjs +246 -0
- package/dist/CardBlogpost-cc208f93.js +1 -0
- package/dist/CardOrganization-d93c9bdb.js +1 -0
- package/dist/CardOrganization-e920be73.mjs +234 -0
- package/dist/CardProduct-92affca1.js +1 -0
- package/dist/CardProduct-fca53299.mjs +193 -0
- package/dist/Checkbox-5dbe7b23.mjs +62 -0
- package/dist/Checkbox-76f09248.js +1 -0
- package/dist/Chips-9d81b215.mjs +214 -0
- package/dist/Chips-d47704e6.js +1 -0
- package/dist/Community-87522a04.mjs +132 -0
- package/dist/Community-aef23aee.js +1 -0
- package/dist/Dashboard-91d73bc5.js +1 -0
- package/dist/Dashboard-ea9035bc.mjs +152 -0
- package/dist/Dropdown-31115457.js +1 -0
- package/dist/Dropdown-cab3605b.mjs +146 -0
- package/dist/EULA-aba6a807.js +1 -0
- package/dist/EditOrder-94bbebff.mjs +221 -0
- package/dist/EditOrder-c070d474.js +1 -0
- package/dist/EmptyState-d65bab5b.js +1 -0
- package/dist/EmptyState-e404b05d.mjs +36 -0
- package/dist/Events-cdfbca78.js +1 -0
- package/dist/Events-e9dd58f7.mjs +123 -0
- package/dist/Feed-22464fcd.js +1 -0
- package/dist/Feed-6e96d3dd.mjs +124 -0
- package/dist/Feed-793b3eef.mjs +146 -0
- package/dist/Feed-7b80704d.mjs +361 -0
- package/dist/Feed-98b47c6f.js +1 -0
- package/dist/Feed-b30ef609.js +1 -0
- package/dist/Feed-c5d4390a.js +1 -0
- package/dist/Feed-d114330c.mjs +112 -0
- package/dist/Field-e2a43424.js +1 -0
- package/dist/Field-e5ad88d3.mjs +75 -0
- package/dist/Field.vue_vue_type_style_index_0_scoped_f4a29b0d_lang-0ea8fbf8.js +1 -0
- package/dist/Field.vue_vue_type_style_index_0_scoped_f4a29b0d_lang-4ed993c7.mjs +1 -0
- package/dist/IconChevronRight-a55f838e.js +1 -0
- package/dist/IconChevronRight-fae9d012.mjs +28 -0
- package/dist/IconCommunity-468dc457.mjs +65 -0
- package/dist/IconCommunity-b339e806.js +1 -0
- package/dist/IconCross-5bf93179.js +1 -0
- package/dist/IconCross-84cb1292.mjs +28 -0
- package/dist/IconEdit-9edfd74d.mjs +21 -0
- package/dist/IconEdit-c0469b45.js +1 -0
- package/dist/Image-245c003d.mjs +480 -0
- package/dist/Image-35d31936.js +9 -0
- package/dist/LabelGooglePlay-24feb437.mjs +31 -0
- package/dist/LabelGooglePlay-f80e5ff0.js +1 -0
- package/dist/LeftoverAdd-08d9fb54.mjs +228 -0
- package/dist/LeftoverAdd-fc673884.js +1 -0
- package/dist/Leftovers-296c0042.js +1 -0
- package/dist/Leftovers-685d9f19.mjs +136 -0
- package/dist/Loader-21f016da.js +1 -0
- package/dist/Loader-cd422786.mjs +41 -0
- package/dist/Loader.vue_vue_type_style_index_0_lang-0ea8fbf8.js +1 -0
- package/dist/Loader.vue_vue_type_style_index_0_lang-4ed993c7.mjs +1 -0
- package/dist/Members-2cb2ff58.mjs +114 -0
- package/dist/Members-85534d1f.js +1 -0
- package/dist/Menu-b5d6a0c7.js +1 -0
- package/dist/Menu-dd7645c1.mjs +13 -0
- package/dist/MenuItem-56ae7f94.js +1 -0
- package/dist/MenuItem-6296d02f.mjs +63 -0
- package/dist/Orders-b64e8cb9.js +1 -0
- package/dist/Orders-ff30db05.mjs +75 -0
- package/dist/Organizations-0cb37d68.js +1 -0
- package/dist/Organizations-d6ef2113.mjs +73 -0
- package/dist/Payments-53e5fecf.js +1 -0
- package/dist/Payments-82e545e1.mjs +87 -0
- package/dist/PlaceholderUserpic-47f6f319.js +1 -0
- package/dist/Popup-0915427c.mjs +74 -0
- package/dist/Popup-795f5c88.js +1 -0
- package/dist/Popup.vue_vue_type_style_index_0_lang-0ea8fbf8.js +1 -0
- package/dist/Popup.vue_vue_type_style_index_0_lang-4ed993c7.mjs +1 -0
- package/dist/Product-5994a8c9.mjs +653 -0
- package/dist/Product-68fa1e9e.js +7 -0
- package/dist/ProductEdit-64207814.mjs +296 -0
- package/dist/ProductEdit-a434240f.js +1 -0
- package/dist/ProductsBackoffice-0c93f9b6.js +1 -0
- package/dist/ProductsBackoffice-3d987c60.mjs +86 -0
- package/dist/ProfileBlogposts-0b81d964.js +1 -0
- package/dist/ProfileBlogposts-b59992cf.mjs +79 -0
- package/dist/ProfileEvents-3f7ca2c1.js +1 -0
- package/dist/ProfileEvents-bbdd62e7.mjs +70 -0
- package/dist/ProfileOrganizations-4734c02e.mjs +73 -0
- package/dist/ProfileOrganizations-d55ee487.js +1 -0
- package/dist/Publics-0762210a.js +1 -0
- package/dist/Publics-660e851c.mjs +45 -0
- package/dist/SelectMulti-58704d69.mjs +1038 -0
- package/dist/SelectMulti-c25765cf.js +1 -0
- package/dist/SkeletonBlogpost-95db0fa9.js +1 -0
- package/dist/SkeletonBlogpost-e0621af7.mjs +16 -0
- package/dist/SkeletonEvent-8690422d.mjs +16 -0
- package/dist/SkeletonEvent-eb284de8.js +1 -0
- package/dist/SkeletonEventShort-6c9e3940.js +1 -0
- package/dist/SkeletonEventShort-f030e56f.mjs +16 -0
- package/dist/SkeletonOrganization-5c09cfc5.js +1 -0
- package/dist/SkeletonOrganization-8690422d.mjs +16 -0
- package/dist/Socials-31c06635.mjs +74 -0
- package/dist/Socials-cceaeaf2.js +1 -0
- package/dist/Tab-054b61f7.mjs +46 -0
- package/dist/Tab-2c1e4224.js +1 -0
- package/dist/Tab.vue_vue_type_style_index_0_lang-0ea8fbf8.js +1 -0
- package/dist/Tab.vue_vue_type_style_index_0_lang-4ed993c7.mjs +1 -0
- package/dist/addMembersQuantity-7147aa4a.js +89 -0
- package/dist/addMembersQuantity-eac999f0.mjs +90 -0
- package/dist/auth-06d35b82.js +7 -0
- package/dist/auth-ec618cb3.mjs +627 -0
- package/dist/auth.client.cjs +7 -7
- package/dist/auth.client.js +22 -19
- package/dist/auth.server.js +1 -1
- package/dist/auth.server.mjs +1 -1
- package/dist/auth.validation-0ce9e326.js +1 -0
- package/dist/auth.validation-ba3606bf.mjs +24 -0
- package/dist/backoffice.client.cjs +1 -1
- package/dist/backoffice.client.js +235 -59
- package/dist/categories-82b28618.js +1 -0
- package/dist/categories-df3240a7.mjs +122 -0
- package/dist/community.client.cjs +1 -1
- package/dist/community.client.js +233 -227
- package/dist/community.server.js +217 -189
- package/dist/community.server.mjs +217 -189
- package/dist/components/Field/Field.vue.d.ts +58 -2
- package/dist/components/Field/Field.vue.d.ts.map +1 -1
- package/dist/components/UploadImage/UploadImage.vue.d.ts +1 -1
- package/dist/dribbble-8e8e169b.js +1 -0
- package/dist/dribbble-ae37c2ac.mjs +127 -0
- package/dist/events.client.cjs +2 -2
- package/dist/events.client.js +1793 -1888
- package/dist/events.server.js +100 -210
- package/dist/events.server.mjs +100 -210
- package/dist/globals.server.js +1 -1
- package/dist/globals.server.mjs +1 -1
- package/dist/icons.client.cjs +1 -0
- package/dist/icons.client.js +84 -0
- package/dist/inputs.validation-d7cef32b.js +1 -0
- package/dist/inputs.validation-db65277a.mjs +83 -0
- package/dist/landing.client.cjs +1 -1
- package/dist/landing.client.js +40 -64
- package/dist/leftovers-66951de6.js +1 -0
- package/dist/leftovers-be37c7a5.mjs +67 -0
- package/dist/legal.client.cjs +1 -1
- package/dist/legal.client.js +7 -4
- package/dist/mailing-76895d59.mjs +50 -0
- package/dist/mailing-9659b3c4.js +49 -0
- package/dist/main.css +1 -1
- package/dist/memberships-12210953.mjs +68 -0
- package/dist/memberships-393765d8.js +1 -0
- package/dist/metadata.schema-147f9902.mjs +212 -0
- package/dist/metadata.schema-93397f9f.js +211 -0
- package/dist/metadata.schema-a539dd65.mjs +210 -0
- package/dist/metadata.schema-e4fe5c57.js +209 -0
- package/dist/modules/community/components/blocks/FooterBlogpost.vue.d.ts +1 -1
- package/dist/modules/community/components/sections/Feed.vue.d.ts +4 -3
- package/dist/modules/events/components/sections/Feed.vue.d.ts +4 -4
- package/dist/modules/events/components/sections/List.vue.d.ts +3 -3
- package/dist/modules/globals/components/blocks/CardFooter.vue.d.ts +8 -0
- package/dist/modules/globals/components/blocks/CardHeader.vue.d.ts +15 -0
- package/dist/modules/globals/components/sections/Feed.vue.d.ts +69 -0
- package/dist/modules/orders/components/pages/EditOrder.vue.d.ts +6 -0
- package/dist/modules/orders/components/pages/Favorites.vue.d.ts +6 -0
- package/dist/modules/orders/components/pages/History.vue.d.ts +6 -0
- package/dist/modules/orders/components/pages/Orders.vue.d.ts +2 -0
- package/dist/modules/orders/components/pages/ViewOrder.vue.d.ts +6 -0
- package/dist/modules/orders/components/sections/Form.vue.d.ts +1 -0
- package/dist/modules/organizations/components/blocks/CardDepartment.vue.d.ts +7 -0
- package/dist/modules/organizations/components/blocks/User.vue.d.ts +1 -1
- package/dist/modules/organizations/components/elements/ButtonToggleMembership.vue.d.ts +1 -1
- package/dist/modules/organizations/components/pages/Members.vue.d.ts +2 -0
- package/dist/modules/organizations/components/sections/Department2.vue.d.ts +7 -0
- package/dist/modules/organizations/components/sections/Feed.vue.d.ts +4 -4
- package/dist/modules/organizations/components/sections/FeedDepartments.vue.d.ts +8 -0
- package/dist/modules/payments/components/pages/Payments.vue.d.ts +2 -0
- package/dist/modules/products/components/blocks/CardLeftover.vue.d.ts +6 -0
- package/dist/modules/products/components/blocks/CardPosition.vue.d.ts +11 -0
- package/dist/modules/products/components/blocks/CardProduct.vue.d.ts +6 -0
- package/dist/modules/products/components/blocks/LeftoverPositions.vue.d.ts +0 -1
- package/dist/modules/products/components/pages/ProductsBackoffice.vue.d.ts +2 -0
- package/dist/modules/products/components/sections/FilterProducts.vue.d.ts +9 -0
- package/dist/modules/products/components/sections/SortProducts.vue.d.ts +10 -0
- package/dist/modules/reports/components/sections/FormReport.vue.d.ts +3 -3
- package/dist/modules/spots/components/blocks/CardSpot.vue.d.ts +7 -0
- package/dist/modules/spots/components/blocks/SpotMemberModify.vue.d.ts +11 -0
- package/dist/modules/spots/components/blocks/SpotSub.vue.d.ts +6 -0
- package/dist/modules/spots/components/pages/Spot.vue.d.ts +7 -0
- package/dist/modules/spots/components/pages/SpotEdit.vue.d.ts +2 -0
- package/dist/modules/spots/components/sections/Feed.vue.d.ts +8 -0
- package/dist/modules/spots/components/sections/PlaceModify.vue.d.ts +9 -0
- package/dist/modules/spots/components/sections/Places.vue.d.ts +9 -0
- package/dist/modules/wallet/components/pages/Wallet.vue.d.ts +2 -0
- package/dist/orders-13c10d49.mjs +85 -0
- package/dist/orders-37f041aa.js +1 -0
- package/dist/organizations-4d18a2e2.js +1 -0
- package/dist/organizations-6ed907e3.mjs +122 -0
- package/dist/organizations.client-01593e4d.js +3 -0
- package/dist/organizations.client-1b9fa66e.mjs +2997 -0
- package/dist/organizations.client.cjs +1 -1
- package/dist/organizations.client.js +75 -51
- package/dist/organizations.server.js +9 -20
- package/dist/organizations.server.mjs +9 -20
- package/dist/products-7960bbd4.js +1 -0
- package/dist/products-bf5783aa.mjs +108 -0
- package/dist/prometheus-framework.cjs.js +17 -17
- package/dist/prometheus-framework.es.js +771 -758
- package/dist/states.validation-03f7cd49.js +1 -0
- package/dist/states.validation-50e3a5a0.mjs +13 -0
- package/dist/style.css +1 -1
- package/dist/users.client.cjs +1 -1
- package/dist/users.client.js +212 -256
- package/dist/users.server.js +1 -1
- package/dist/users.server.mjs +1 -1
- package/package.json +5 -1
- package/src/components/Field/Field.vue +34 -9
- package/src/components/SelectMulti/SelectMulti.vue +18 -22
- package/src/modules/auth/store/auth.js +34 -15
- package/src/modules/backoffice/components/pages/Dashboard.vue +91 -0
- package/src/modules/backoffice/router/admin.js +0 -28
- package/src/modules/backoffice/router/backoffice.js +131 -4
- package/src/modules/community/components/blocks/CardBlogpost.vue +1 -1
- package/src/modules/community/components/pages/Blog.vue +1 -0
- package/src/modules/community/components/sections/Comments.vue +1 -1
- package/src/modules/community/components/sections/Feed.vue +6 -0
- package/src/modules/community/controllers/blog.controller.js +129 -285
- package/src/modules/community/controllers/reactions.controller.js +2 -0
- package/src/modules/community/controllers/utils/queryProcessor.js +56 -0
- package/src/modules/community/controllers/utils/queryProcessorReactions.js +63 -0
- package/src/modules/community/store/blogposts.js +5 -5
- package/src/modules/events/components/blocks/CardEvent.vue +2 -3
- package/src/modules/events/components/pages/Events.vue +4 -4
- package/src/modules/events/components/sections/Feed.vue +4 -4
- package/src/modules/events/components/sections/List.vue +2 -2
- package/src/modules/events/controllers/events.controller.js +8 -6
- package/src/modules/events/controllers/utils/queryProcessor.js +111 -1
- package/src/modules/events/models/event.model.js +0 -4
- package/src/modules/events/store/events.js +5 -7
- package/src/{components/CardHeader → modules/globals/components/blocks}/CardHeader.vue +31 -4
- package/src/modules/globals/components/sections/Feed.vue +136 -0
- package/src/modules/globals/controllers/utils/queryProcessor.js +19 -117
- package/src/modules/globals/models/engagement.schema.js +29 -25
- package/src/modules/globals/utils/mailing.js +1 -1
- package/src/modules/icons/icons.client.js +51 -0
- package/src/modules/marketplace/components/layouts/Marketplace.vue +1 -1
- package/src/modules/marketplace/components/pages/Catalog.vue +3 -4
- package/src/modules/marketplace/router/marketplace.js +0 -11
- package/src/modules/middlewares/client/auth.validation.js +1 -1
- package/src/modules/orders/components/blocks/CardOrderItem.vue +1 -2
- package/src/modules/orders/components/pages/EditOrder.vue +238 -0
- package/src/modules/{backoffice → orders}/components/pages/Favorites.vue +2 -2
- package/src/modules/orders/components/pages/Order.vue +28 -34
- package/src/modules/orders/components/pages/Orders.vue +90 -0
- package/src/modules/{backoffice/components/pages/History.vue → orders/components/pages/ViewOrder.vue} +0 -8
- package/src/modules/orders/components/sections/Form.vue +52 -34
- package/src/modules/orders/controllers/orders.controller.js +102 -72
- package/src/modules/orders/models/order.model.js +30 -22
- package/src/modules/orders/router/orders.router.js +30 -0
- package/src/modules/orders/routes/orders.routes.js +23 -13
- package/src/modules/orders/store/orders.js +67 -40
- package/src/modules/organizations/components/{sections/Department.vue → blocks/CardDepartment.vue} +1 -10
- package/src/modules/organizations/components/blocks/CardOrganization.vue +13 -9
- package/src/modules/organizations/components/pages/DepartmentEdit.vue +3 -3
- package/src/modules/organizations/components/{sections/MembersTab.vue → pages/Members.vue} +23 -8
- package/src/modules/organizations/components/pages/Organization.vue +80 -46
- package/src/modules/organizations/components/pages/Organizations.vue +45 -90
- package/src/modules/organizations/components/sections/{StructureTab.vue → FeedDepartments.vue} +5 -5
- package/src/modules/organizations/components/sections/Organizations.vue +1 -2
- package/src/modules/organizations/components/sections/Publics.vue +3 -2
- package/src/modules/organizations/controllers/organizations.controller.js +8 -21
- package/src/modules/organizations/controllers/organizations.new.controller.js +372 -0
- package/src/modules/organizations/controllers/utils/addUserStatusFields.js +53 -48
- package/src/modules/organizations/controllers/utils/queryProcessor.js +87 -0
- package/src/modules/organizations/controllers/utils/queryProcessorOrganizations.js +25 -0
- package/src/modules/organizations/organizations.client.js +42 -46
- package/src/modules/organizations/router/departments.router.js +29 -0
- package/src/modules/organizations/router/members.router.js +19 -0
- package/src/modules/organizations/router/organizations.js +12 -88
- package/src/modules/organizations/router/organizations.router.js +38 -0
- package/src/modules/organizations/router/products.router.js +24 -0
- package/src/modules/organizations/store/departments.js +108 -0
- package/src/modules/{backoffice/components/admin/Orders.vue → payments/components/pages/Payments.vue} +0 -15
- package/src/modules/products/components/blocks/{Leftover.vue → CardLeftover.vue} +21 -12
- package/src/modules/products/components/blocks/CardPosition.vue +84 -0
- package/src/modules/products/components/blocks/LeftoverPositions.vue +65 -136
- package/src/modules/products/components/pages/LeftoverAdd.vue +133 -88
- package/src/modules/products/components/pages/Leftovers.vue +91 -64
- package/src/modules/products/components/pages/Product.vue +3 -3
- package/src/modules/products/components/pages/Products.vue +42 -263
- package/src/modules/products/components/pages/ProductsBackoffice.vue +92 -0
- package/src/modules/products/components/sections/FilterProducts.vue +180 -0
- package/src/modules/products/components/sections/PopularProducts.vue +2 -2
- package/src/modules/products/components/sections/SectionProduct.vue +18 -3
- package/src/modules/products/components/sections/SortProducts.vue +76 -0
- package/src/modules/products/controllers/leftovers.controller.js +51 -45
- package/src/modules/products/controllers/modifications.controller.js +66 -0
- package/src/modules/products/controllers/products.controller.js +67 -111
- package/src/modules/products/models/leftover.model.js +12 -9
- package/src/modules/products/models/product.model.js +1 -0
- package/src/modules/products/router/products.router.js +46 -0
- package/src/modules/products/routes/products.routes.js +4 -9
- package/src/modules/products/store/leftovers.js +56 -59
- package/src/modules/products/store/products.js +21 -22
- package/src/modules/spots/components/blocks/CardSpot.vue +104 -0
- package/src/modules/spots/components/blocks/SpotMemberModify.vue +92 -0
- package/src/modules/spots/components/blocks/SpotSub.vue +24 -0
- package/src/modules/spots/components/pages/Map.vue +2 -2
- package/src/modules/spots/components/pages/Spot.vue +107 -0
- package/src/modules/spots/components/pages/SpotEdit.vue +319 -0
- package/src/modules/spots/components/sections/Feed.vue +64 -0
- package/src/modules/spots/controllers/spots.controller.js +83 -0
- package/src/modules/spots/models/spot.model.js +72 -0
- package/src/modules/spots/router/spots.js +34 -1
- package/src/modules/spots/routes/spots.routes.js +31 -0
- package/src/modules/spots/store/spots.js +15 -15
- package/src/modules/users/components/pages/Profile.vue +2 -3
- package/src/modules/users/components/pages/ProfileBlogposts.vue +1 -1
- package/src/styles/components/block.scss +2 -4
- package/src/modules/backoffice/components/admin/LeftoverAdd.vue +0 -157
- package/src/modules/backoffice/components/admin/Leftovers.vue +0 -119
- package/src/modules/backoffice/components/admin/Order.vue +0 -199
- package/src/modules/backoffice/components/admin/Product.vue +0 -28
- package/src/modules/backoffice/components/admin/Products.vue +0 -82
- package/src/modules/backoffice/components/pages/Organizations.vue +0 -104
- package/src/modules/community/controllers/blog.new.controller.js +0 -290
- package/src/modules/organizations/components/blocks/DepartmentSubDepartmentModify.vue +0 -92
- package/src/modules/organizations/components/elements/ButtonFollow.vue +0 -84
- package/src/modules/organizations/components/pages/OrganizationsAccount.vue +0 -110
- package/src/modules/organizations/controllers/utils/excludeBlockedMembers.js +0 -18
- /package/src/{components/CardFooter → modules/globals/components/blocks}/CardFooter.vue +0 -0
- /package/src/modules/{orders/controllers → payments/controller}/payments.controller.js +0 -0
- /package/src/modules/{orders → payments}/routes/payments.routes.js +0 -0
- /package/src/modules/{orders → payments}/store/payments.js +0 -0
- /package/src/modules/products/components/blocks/{ProductCard.vue → CardProduct.vue} +0 -0
- /package/src/modules/{organizations → spots}/components/sections/PlaceModify.vue +0 -0
- /package/src/modules/{organizations → spots}/components/sections/Places.vue +0 -0
- /package/src/modules/{backoffice → wallet}/components/pages/Wallet.vue +0 -0
package/dist/community.server.js
CHANGED
@@ -1,217 +1,245 @@
|
|
1
1
|
"use strict";
|
2
2
|
const _commonjsHelpers = require("./_commonjsHelpers-3b53548e.js");
|
3
|
-
require("uuid");
|
4
3
|
const require$$0 = require("mongoose");
|
4
|
+
const metadata_schema = require("./metadata.schema-e4fe5c57.js");
|
5
|
+
require("util");
|
6
|
+
require("uuid");
|
5
7
|
const index = require("./index-21dfdbd9.js");
|
6
|
-
const metadata_schema = require("./metadata.schema-4f856191.js");
|
7
8
|
require("jsonwebtoken");
|
8
9
|
require("mongodb");
|
9
|
-
|
10
|
+
function getPeriodConditions(period) {
|
11
|
+
const date = /* @__PURE__ */ new Date();
|
12
|
+
switch (period) {
|
13
|
+
case "today":
|
14
|
+
date.setDate(date.getDate() - 1);
|
15
|
+
break;
|
16
|
+
case "week":
|
17
|
+
date.setDate(date.getDate() - 7);
|
18
|
+
break;
|
19
|
+
case "month":
|
20
|
+
date.setMonth(date.getMonth() - 1);
|
21
|
+
break;
|
22
|
+
case "year":
|
23
|
+
date.setFullYear(date.getFullYear() - 1);
|
24
|
+
break;
|
25
|
+
default:
|
26
|
+
date.setFullYear(date.getFullYear() - 1);
|
27
|
+
}
|
28
|
+
if (date) {
|
29
|
+
return [{ $match: { createdAt: { $gte: date } } }];
|
30
|
+
} else {
|
31
|
+
return [];
|
32
|
+
}
|
33
|
+
}
|
34
|
+
async function getCategoryConditions(category, user) {
|
35
|
+
const aggregationStages = [];
|
36
|
+
if (category) {
|
37
|
+
switch (category) {
|
38
|
+
case "featured":
|
39
|
+
aggregationStages.push({ $match: { tags: { $in: ["Featured"] } } });
|
40
|
+
break;
|
41
|
+
case "popular":
|
42
|
+
aggregationStages.push({ $sort: { views: -1, likes: -1 } });
|
43
|
+
break;
|
44
|
+
case "new":
|
45
|
+
aggregationStages.push({ $sort: { createdAt: -1 } });
|
46
|
+
break;
|
47
|
+
}
|
48
|
+
}
|
49
|
+
console.log(aggregationStages);
|
50
|
+
return aggregationStages;
|
51
|
+
}
|
52
|
+
var queryProcessor$2 = {
|
53
|
+
getPeriodConditions,
|
54
|
+
getCategoryConditions
|
55
|
+
// ... other functions that you might want to export
|
56
|
+
};
|
57
|
+
const ObjectId$2 = require$$0.Types.ObjectId;
|
58
|
+
function getCommentsLookupStage() {
|
59
|
+
return {
|
60
|
+
$lookup: {
|
61
|
+
from: "comments",
|
62
|
+
localField: "_id",
|
63
|
+
foreignField: "target",
|
64
|
+
as: "comments"
|
65
|
+
}
|
66
|
+
};
|
67
|
+
}
|
68
|
+
function getReactionsLookupStage() {
|
69
|
+
return {
|
70
|
+
$lookup: {
|
71
|
+
from: "reactions",
|
72
|
+
localField: "_id",
|
73
|
+
foreignField: "target",
|
74
|
+
as: "reactions"
|
75
|
+
}
|
76
|
+
};
|
77
|
+
}
|
78
|
+
function getReactionsCommentsFields(user) {
|
79
|
+
return {
|
80
|
+
$addFields: {
|
81
|
+
numberOfComments: { $size: "$comments" },
|
82
|
+
numberOfReactions: { $size: "$reactions" },
|
83
|
+
isReacted: {
|
84
|
+
$in: [
|
85
|
+
new ObjectId$2(user),
|
86
|
+
// make sure db is accessible or pass as param
|
87
|
+
"$reactions.user"
|
88
|
+
]
|
89
|
+
},
|
90
|
+
reactionId: {
|
91
|
+
$let: {
|
92
|
+
vars: {
|
93
|
+
reactionIndex: {
|
94
|
+
$indexOfArray: [
|
95
|
+
"$reactions.user",
|
96
|
+
new ObjectId$2(user)
|
97
|
+
// same here for db accessibility
|
98
|
+
]
|
99
|
+
}
|
100
|
+
},
|
101
|
+
in: {
|
102
|
+
$cond: [
|
103
|
+
{ $gte: ["$$reactionIndex", 0] },
|
104
|
+
{ $arrayElemAt: ["$reactions._id", "$$reactionIndex"] },
|
105
|
+
null
|
106
|
+
]
|
107
|
+
}
|
108
|
+
}
|
109
|
+
}
|
110
|
+
}
|
111
|
+
};
|
112
|
+
}
|
113
|
+
var queryProcessorReactions$1 = {
|
114
|
+
getCommentsLookupStage,
|
115
|
+
getReactionsLookupStage,
|
116
|
+
getReactionsCommentsFields
|
117
|
+
};
|
118
|
+
const ObjectId$1 = require$$0.Types.ObjectId;
|
119
|
+
async function getBlockedMembers(Membership, userId) {
|
10
120
|
const memberships = await Membership.find({ user: userId });
|
11
121
|
return memberships.filter((membership) => membership.role === "blocked").map((membership) => membership.target);
|
12
122
|
}
|
13
|
-
function addConditionsForBlocked
|
123
|
+
function addConditionsForBlocked(matchStage, field, blockedMembers) {
|
14
124
|
const conditionsForBlocked = { "$nin": blockedMembers };
|
15
125
|
if (matchStage[field]) {
|
16
126
|
matchStage[field] = { "$eq": matchStage[field], ...conditionsForBlocked };
|
17
127
|
} else {
|
18
128
|
matchStage[field] = conditionsForBlocked;
|
19
129
|
}
|
130
|
+
return matchStage;
|
20
131
|
}
|
21
|
-
|
22
|
-
|
23
|
-
const
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
let matchStage = {};
|
30
|
-
const options = {
|
31
|
-
skip: parseInt(req.query.skip) || 0,
|
32
|
-
limit: parseInt(req.query.limit) || 20
|
33
|
-
};
|
34
|
-
if (req.query.url) {
|
35
|
-
matchStage["url"] = req.query.url;
|
36
|
-
await Blogpost.findOneAndUpdate({ url: req.query.url }, { $inc: { views: 1 } }, { new: true });
|
37
|
-
}
|
38
|
-
if (req.query.status) {
|
39
|
-
matchStage["status"] = req.query.status;
|
40
|
-
}
|
41
|
-
if (req.query.owner) {
|
42
|
-
matchStage["owner.target"] = new db.mongoose.Types.ObjectId(req.query.owner);
|
132
|
+
const AggregationProcessor = {
|
133
|
+
getMembersByRole: async (Membership, userId, role) => {
|
134
|
+
const memberships = await Membership.find({ user: userId, role });
|
135
|
+
return memberships.map((membership) => new ObjectId$1(membership.target));
|
136
|
+
},
|
137
|
+
generateMatchStage: async (Membership, userOrFollowing, role, operation = "$in") => {
|
138
|
+
if (!userOrFollowing) {
|
139
|
+
return [];
|
43
140
|
}
|
44
|
-
|
45
|
-
|
141
|
+
const members = await AggregationProcessor.getMembersByRole(Membership, userOrFollowing, role);
|
142
|
+
if (members.length === 0) {
|
143
|
+
return [];
|
46
144
|
}
|
47
|
-
|
48
|
-
|
145
|
+
const typeMap = {
|
146
|
+
"owner.target": "organization",
|
147
|
+
"creator.target": "user"
|
148
|
+
};
|
149
|
+
const matchConditions = Object.keys(typeMap).map((key) => ({
|
150
|
+
[key]: { [operation]: members }
|
151
|
+
}));
|
152
|
+
return [{
|
153
|
+
$match: { $or: matchConditions }
|
154
|
+
}];
|
155
|
+
},
|
156
|
+
getBlockedStage: async (Membership, user) => {
|
157
|
+
if (user) {
|
158
|
+
const blockedMembers = await getBlockedMembers(Membership, user);
|
49
159
|
console.log(blockedMembers);
|
50
160
|
if (blockedMembers.length > 0) {
|
51
|
-
|
52
|
-
addConditionsForBlocked(
|
161
|
+
let stage = {};
|
162
|
+
addConditionsForBlocked(stage, "owner.target", blockedMembers);
|
163
|
+
addConditionsForBlocked(stage, "creator.target", blockedMembers);
|
164
|
+
console.log("Maths is" + [{
|
165
|
+
$match: stage
|
166
|
+
}]);
|
167
|
+
return [{
|
168
|
+
$match: stage
|
169
|
+
}];
|
170
|
+
} else {
|
171
|
+
return [];
|
53
172
|
}
|
173
|
+
} else {
|
174
|
+
return [];
|
54
175
|
}
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
|
98
|
-
|
99
|
-
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
|
107
|
-
|
108
|
-
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
});
|
117
|
-
query.push({
|
118
|
-
$addFields: {
|
119
|
-
numberOfComments: { $size: "$comments" },
|
120
|
-
numberOfReactions: { $size: "$reactions" },
|
121
|
-
isReacted: {
|
122
|
-
$in: [
|
123
|
-
new db.mongoose.Types.ObjectId(req.query.user),
|
124
|
-
"$reactions.user"
|
125
|
-
]
|
126
|
-
},
|
127
|
-
reactionId: {
|
128
|
-
$let: {
|
129
|
-
vars: {
|
130
|
-
reactionIndex: {
|
131
|
-
$indexOfArray: [
|
132
|
-
"$reactions.user",
|
133
|
-
new db.mongoose.Types.ObjectId(req.query.user)
|
134
|
-
]
|
135
|
-
}
|
136
|
-
},
|
137
|
-
in: {
|
138
|
-
$cond: [
|
139
|
-
{ $gte: ["$$reactionIndex", 0] },
|
140
|
-
{ $arrayElemAt: ["$reactions._id", "$$reactionIndex"] },
|
141
|
-
null
|
142
|
-
]
|
143
|
-
}
|
144
|
-
}
|
145
|
-
}
|
146
|
-
}
|
147
|
-
});
|
148
|
-
query.push(
|
149
|
-
{
|
150
|
-
$lookup: {
|
151
|
-
from: "users",
|
152
|
-
localField: "creator.target",
|
153
|
-
foreignField: "_id",
|
154
|
-
as: "creatorUser"
|
155
|
-
}
|
156
|
-
},
|
157
|
-
{
|
158
|
-
$lookup: {
|
159
|
-
from: "organizations",
|
160
|
-
localField: "creator.target",
|
161
|
-
foreignField: "_id",
|
162
|
-
as: "creatorOrganization"
|
163
|
-
}
|
164
|
-
},
|
165
|
-
// Для owner
|
166
|
-
{
|
167
|
-
$lookup: {
|
168
|
-
from: "users",
|
169
|
-
localField: "owner.target",
|
170
|
-
foreignField: "_id",
|
171
|
-
as: "ownerUser"
|
172
|
-
}
|
173
|
-
},
|
174
|
-
{
|
175
|
-
$lookup: {
|
176
|
-
from: "organizations",
|
177
|
-
localField: "owner.target",
|
178
|
-
foreignField: "_id",
|
179
|
-
as: "ownerOrganization"
|
180
|
-
}
|
181
|
-
},
|
182
|
-
{
|
183
|
-
$addFields: {
|
184
|
-
"creator.target": {
|
185
|
-
$cond: [
|
186
|
-
{ $eq: ["$creator.type", "user"] },
|
187
|
-
{ $arrayElemAt: ["$creatorUser", 0] },
|
188
|
-
{ $arrayElemAt: ["$creatorOrganization", 0] }
|
189
|
-
]
|
190
|
-
},
|
191
|
-
"owner.target": {
|
192
|
-
$cond: [
|
193
|
-
{ $eq: ["$owner.type", "user"] },
|
194
|
-
{ $arrayElemAt: ["$ownerUser", 0] },
|
195
|
-
{ $arrayElemAt: ["$ownerOrganization", 0] }
|
196
|
-
]
|
197
|
-
}
|
198
|
-
}
|
199
|
-
}
|
200
|
-
);
|
201
|
-
query.push({
|
202
|
-
$project: {
|
203
|
-
comments: 0,
|
204
|
-
reactions: 0
|
205
|
-
}
|
206
|
-
});
|
207
|
-
query.push({ $skip: options.skip });
|
208
|
-
query.push({ $limit: options.limit });
|
176
|
+
},
|
177
|
+
getFollowingStage: async (Membership, following) => {
|
178
|
+
return await AggregationProcessor.generateMatchStage(Membership, following, "subscriber", "$in");
|
179
|
+
}
|
180
|
+
};
|
181
|
+
var queryProcessor$1 = AggregationProcessor;
|
182
|
+
const queryProcessor = queryProcessor$2;
|
183
|
+
const queryProcessorReactions = queryProcessorReactions$1;
|
184
|
+
const queryProcessorOrganizations = queryProcessor$1;
|
185
|
+
const queryProcessorGlobals = metadata_schema.queryProcessor;
|
186
|
+
const controllerFactory$3 = (db) => {
|
187
|
+
const Blogpost = db.blogpost;
|
188
|
+
db.organization;
|
189
|
+
const Membership = db.membership;
|
190
|
+
const read = async (req, res) => {
|
191
|
+
let stages = [];
|
192
|
+
stages = [
|
193
|
+
...queryProcessorGlobals.getBasicOptions(
|
194
|
+
req.query
|
195
|
+
),
|
196
|
+
...queryProcessorGlobals.getTagsOptions(
|
197
|
+
req.query.tags
|
198
|
+
),
|
199
|
+
...queryProcessor.getPeriodConditions(
|
200
|
+
req.query.period
|
201
|
+
),
|
202
|
+
...await queryProcessor.getCategoryConditions(
|
203
|
+
req.query.category
|
204
|
+
),
|
205
|
+
// Following
|
206
|
+
...await queryProcessorOrganizations.getFollowingStage(
|
207
|
+
Membership,
|
208
|
+
req.query.following
|
209
|
+
),
|
210
|
+
// Blocking
|
211
|
+
...await queryProcessorOrganizations.getBlockedStage(
|
212
|
+
Membership,
|
213
|
+
req.query.user
|
214
|
+
),
|
215
|
+
queryProcessorReactions.getCommentsLookupStage(),
|
216
|
+
queryProcessorReactions.getReactionsLookupStage(),
|
217
|
+
queryProcessorReactions.getReactionsCommentsFields(
|
218
|
+
req.query.user
|
219
|
+
),
|
220
|
+
// Sorting and Pagination
|
221
|
+
...queryProcessorGlobals.getSortingOptions(
|
222
|
+
req.query.sortParam,
|
223
|
+
req.query.sortOrder
|
224
|
+
),
|
225
|
+
...queryProcessorGlobals.getPaginationOptions(
|
226
|
+
req.query.skip,
|
227
|
+
req.query.limit
|
228
|
+
),
|
229
|
+
// For creator
|
230
|
+
queryProcessorGlobals.getCreatorUserLookupStage(),
|
231
|
+
queryProcessorGlobals.getCreatorOrganizationLookupStage(),
|
232
|
+
// For owner
|
233
|
+
queryProcessorGlobals.getOwnerUserLookupStage(),
|
234
|
+
queryProcessorGlobals.getOwnerOrganizationLookupStage(),
|
235
|
+
queryProcessorGlobals.getAddFieldsCreatorOwnerStage()
|
236
|
+
];
|
209
237
|
try {
|
210
|
-
|
238
|
+
console.log(stages);
|
239
|
+
const posts = await Blogpost.aggregate(stages).exec();
|
211
240
|
if (posts.length === 0) {
|
212
241
|
return res.status(200).send([]);
|
213
242
|
}
|
214
|
-
console.log(posts);
|
215
243
|
res.status(200).send(posts);
|
216
244
|
} catch (err) {
|
217
245
|
console.log(err);
|
@@ -601,7 +629,7 @@ var blogpost_model = (db) => {
|
|
601
629
|
strict: false
|
602
630
|
});
|
603
631
|
applyCommonSchema(BlogpostSchema);
|
604
|
-
applyEngagementSchema(BlogpostSchema
|
632
|
+
applyEngagementSchema(BlogpostSchema);
|
605
633
|
applyOwnershipSchema(BlogpostSchema, db);
|
606
634
|
applyMetadataSchema(BlogpostSchema);
|
607
635
|
const Blogpost = db.mongoose.model("Blogpost", BlogpostSchema);
|