@ozdao/prometheus-framework 0.2.29 → 0.2.31
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/addMembersQuantity-3505b6f3.mjs +98 -0
- package/dist/addMembersQuantity-fb552ca0.js +97 -0
- package/dist/auth.server.js +6 -9
- package/dist/auth.server.mjs +6 -9
- package/dist/community.server.js +28 -21
- package/dist/community.server.mjs +28 -21
- package/dist/events.server.js +1 -1
- package/dist/events.server.mjs +1 -1
- package/dist/files.server.js +114 -111
- package/dist/files.server.mjs +114 -111
- package/dist/gallery.server.js +3 -3
- package/dist/gallery.server.mjs +3 -3
- package/dist/globals.server.js +1 -1
- package/dist/globals.server.mjs +1 -1
- package/dist/index-a8dffc0c.js +213 -0
- package/dist/index-d769324d.mjs +214 -0
- package/dist/mailing-37c2ba41.mjs +68 -0
- package/dist/mailing-fe16a26a.js +67 -0
- package/dist/main.css +1 -1
- package/dist/middlewares.server.js +1 -1
- package/dist/middlewares.server.mjs +1 -1
- package/dist/organizations.server.js +125 -25
- package/dist/organizations.server.mjs +125 -25
- package/dist/prometheus-framework/src/components/Dropdown/Dropdown.vue.cjs +1 -1
- package/dist/prometheus-framework/src/components/Dropdown/Dropdown.vue.js +49 -2
- package/dist/prometheus-framework/src/components/Dropdown/Dropdown.vue2.cjs +1 -1
- package/dist/prometheus-framework/src/components/Dropdown/Dropdown.vue2.js +2 -49
- package/dist/prometheus-framework/src/components/Select/Select.vue.cjs +1 -1
- package/dist/prometheus-framework/src/components/Select/Select.vue.js +78 -2
- package/dist/prometheus-framework/src/components/Select/Select.vue2.cjs +1 -1
- package/dist/prometheus-framework/src/components/Select/Select.vue2.js +2 -78
- package/dist/prometheus-framework/src/modules/backoffice/components/pages/Dashboard.vue.cjs +1 -1
- package/dist/prometheus-framework/src/modules/backoffice/components/pages/Dashboard.vue.js +1 -1
- package/dist/prometheus-framework/src/modules/community/components/layouts/Community.vue.cjs +1 -1
- package/dist/prometheus-framework/src/modules/community/components/layouts/Community.vue.js +1 -1
- package/dist/prometheus-framework/src/modules/community/components/pages/CreateBlogPost.vue.cjs +1 -1
- package/dist/prometheus-framework/src/modules/community/components/pages/CreateBlogPost.vue.js +1 -1
- package/dist/prometheus-framework/src/modules/constructor/components/elements/Textarea.vue.cjs +4 -1
- package/dist/prometheus-framework/src/modules/constructor/components/elements/Textarea.vue.js +62 -2
- package/dist/prometheus-framework/src/modules/constructor/components/elements/Textarea.vue2.cjs +1 -4
- package/dist/prometheus-framework/src/modules/constructor/components/elements/Textarea.vue2.js +2 -62
- package/dist/prometheus-framework/src/modules/constructor/components/sections/Constructor.vue.cjs +1 -1
- package/dist/prometheus-framework/src/modules/constructor/components/sections/Constructor.vue.js +1 -1
- package/dist/prometheus-framework/src/modules/events/components/layouts/layoutEvents.vue.cjs +1 -1
- package/dist/prometheus-framework/src/modules/events/components/layouts/layoutEvents.vue.js +1 -1
- package/dist/prometheus-framework/src/modules/events/components/pages/EditEvent.vue.cjs +1 -1
- package/dist/prometheus-framework/src/modules/events/components/pages/EditEvent.vue.js +1 -1
- package/dist/prometheus-framework/src/modules/events/components/pages/Events.vue.cjs +1 -1
- package/dist/prometheus-framework/src/modules/events/components/pages/Events.vue.js +2 -2
- package/dist/prometheus-framework/src/modules/gallery/components/sections/BackofficeGallery.vue.cjs +1 -1
- package/dist/prometheus-framework/src/modules/gallery/components/sections/BackofficeGallery.vue.js +1 -1
- package/dist/prometheus-framework/src/modules/gallery/components/sections/GalleryWithCategories.vue.cjs +1 -1
- package/dist/prometheus-framework/src/modules/gallery/components/sections/GalleryWithCategories.vue.js +1 -1
- package/dist/prometheus-framework/src/modules/globals/components/blocks/CardHeader.vue.cjs +1 -1
- package/dist/prometheus-framework/src/modules/globals/components/blocks/CardHeader.vue.js +1 -1
- package/dist/prometheus-framework/src/modules/legal/components/pages/Legal.vue.cjs +1 -1
- package/dist/prometheus-framework/src/modules/legal/components/pages/Legal.vue.js +1 -1
- package/dist/prometheus-framework/src/modules/mobile/components/Menu/Menu.vue.cjs +1 -1
- package/dist/prometheus-framework/src/modules/mobile/components/Menu/Menu.vue.js +11 -2
- package/dist/prometheus-framework/src/modules/mobile/components/Menu/Menu.vue2.cjs +1 -1
- package/dist/prometheus-framework/src/modules/mobile/components/Menu/Menu.vue2.js +2 -11
- package/dist/prometheus-framework/src/modules/organizations/components/blocks/DepartmentMemberModify.vue.cjs +1 -1
- package/dist/prometheus-framework/src/modules/organizations/components/blocks/DepartmentMemberModify.vue.js +1 -1
- package/dist/prometheus-framework/src/modules/organizations/components/pages/DepartmentEdit.vue.cjs +1 -1
- package/dist/prometheus-framework/src/modules/organizations/components/pages/DepartmentEdit.vue.js +1 -1
- package/dist/prometheus-framework/src/modules/organizations/components/pages/Organization.vue.cjs +1 -1
- package/dist/prometheus-framework/src/modules/organizations/components/pages/Organization.vue.js +2 -2
- package/dist/prometheus-framework/src/modules/organizations/components/pages/OrganizationEdit.vue.cjs +1 -1
- package/dist/prometheus-framework/src/modules/organizations/components/pages/OrganizationEdit.vue.js +1 -1
- package/dist/prometheus-framework/src/modules/organizations/components/sections/DetailsTab.vue.cjs +1 -1
- package/dist/prometheus-framework/src/modules/organizations/components/sections/DetailsTab.vue.js +1 -1
- package/dist/prometheus-framework/src/modules/organizations/components/sections/MembersAdd.vue.cjs +1 -1
- package/dist/prometheus-framework/src/modules/organizations/components/sections/MembersAdd.vue.js +1 -1
- package/dist/prometheus-framework/src/modules/organizations/components/sections/Organizations.vue.cjs +1 -1
- package/dist/prometheus-framework/src/modules/organizations/components/sections/Organizations.vue.js +2 -2
- package/dist/prometheus-framework/src/modules/reports/components/sections/FormReport.vue.cjs +1 -1
- package/dist/prometheus-framework/src/modules/reports/components/sections/FormReport.vue.js +1 -1
- package/dist/prometheus-framework/src/modules/users/components/pages/Profile.vue.cjs +1 -1
- package/dist/prometheus-framework/src/modules/users/components/pages/Profile.vue.js +2 -2
- package/dist/prometheus-framework.cjs.js +30 -29
- package/dist/prometheus-framework.es.js +2478 -2282
- package/dist/reports.server.js +1 -1
- package/dist/reports.server.mjs +1 -1
- package/dist/style.css +1 -1
- package/dist/users.server.js +1 -1
- package/dist/users.server.mjs +1 -1
- package/package.json +4 -2
- package/src/assets/images/logo.svg +7 -7
- package/src/components/Block/Block.vue +77 -0
- package/src/components/Breadcrumbs/Breadcrumbs.vue +2 -2
- package/src/components/Button/Button.vue +32 -227
- package/src/components/Checkbox/Checkbox.vue +1 -1
- package/src/components/Chips/Chips.vue +8 -8
- package/src/components/DatePicker/DatePicker.vue +3 -4
- package/src/components/EditImages/EditImages.vue +32 -14
- package/src/{modules/globals/components/sections → components/Feed}/Feed.vue +60 -45
- package/src/components/FieldBig/FieldBig.vue +16 -5
- package/src/components/FieldPhone/FieldPhone.vue +2 -1
- package/src/components/Footer/Footer.vue +36 -27
- package/src/components/Header/Header.vue +161 -166
- package/src/components/Loader/Loader.vue +9 -2
- package/src/components/LocationMarker/LocationMarker.vue +38 -12
- package/src/components/LocationSelection/LocationSelection.vue +67 -75
- package/src/components/Magnifier/Magnifier.vue +3 -3
- package/src/components/Navigation/Navigation.vue +16 -16
- package/src/components/Popup/Popup.vue +8 -6
- package/src/components/Select/Select.vue +35 -6
- package/src/components/SelectMulti/SelectMulti.vue +5 -13
- package/src/components/Shader/Shader.vue +128 -0
- package/src/components/Sidebar/Sidebar.vue +71 -35
- package/src/components/Spoiler/Spoiler.vue +1 -1
- package/src/components/Tab/Tab.vue +1 -1
- package/src/components/Tooltip/Tooltip.vue +1 -1
- package/src/components/UploadImage/UploadImage.vue +4 -4
- package/src/components/UploadImageMultiple/UploadImageMultiple.vue +54 -10
- package/src/modules/applications/controllers/applications.controller.js +0 -1
- package/src/modules/auth/components/pages/EnterCode.vue +1 -1
- package/src/modules/auth/components/pages/EnterPassword.vue +3 -3
- package/src/modules/auth/components/pages/ResetPassword.vue +1 -2
- package/src/modules/auth/components/pages/SignIn.vue +26 -10
- package/src/modules/auth/components/pages/SignUp.vue +1 -2
- package/src/modules/auth/controllers/twofa.controller.js +4 -4
- package/src/modules/auth/localization/EnterCode.json +2 -2
- package/src/modules/auth/localization/EnterPassword.json +2 -2
- package/src/modules/auth/localization/ResetPassword.json +2 -2
- package/src/modules/auth/localization/SignIn.json +3 -3
- package/src/modules/auth/localization/SignUp.json +3 -3
- package/src/modules/auth/utils/server/verifyAppleIdToken.js +0 -1
- package/src/modules/backoffice/components/layouts/Backoffice.vue +1 -1
- package/src/modules/backoffice/components/pages/Dashboard.vue +171 -120
- package/src/modules/backoffice/router/backoffice.js +119 -129
- package/src/modules/chats/components/blocks/ChatMessage.vue +25 -0
- package/src/modules/chats/components/pages/ChatPage.vue +50 -0
- package/src/modules/chats/components/sections/ChatWindow.vue +38 -0
- package/src/modules/chats/controllers/chats.controller.js +32 -0
- package/src/modules/chats/models/chat.model.js +26 -0
- package/src/modules/chats/routes/chats.routes.js +53 -0
- package/src/modules/chats/store/chat.store.js +61 -0
- package/src/modules/community/components/blocks/CardBlogpost.vue +19 -4
- package/src/modules/community/components/layouts/Community.vue +96 -39
- package/src/modules/community/components/pages/Blog.vue +4 -3
- package/src/modules/community/components/pages/BlogPost.vue +10 -1
- package/src/modules/community/components/pages/CreateBlogPost.vue +36 -17
- package/src/modules/community/components/sections/HotPosts.vue +3 -3
- package/src/modules/community/components/sections/JoinUs.vue +19 -13
- package/src/modules/community/controllers/blog.controller.js +3 -4
- package/src/modules/community/controllers/utils/queryProcessor.js +16 -17
- package/src/modules/community/models/blogpost.model.js +6 -3
- package/src/modules/community/store/blogposts.js +1 -0
- package/src/modules/constructor/components/elements/Embed.vue +12 -1
- package/src/modules/constructor/components/elements/ImageUpload.vue +2 -2
- package/src/modules/constructor/components/elements/Textarea.vue +6 -1
- package/src/modules/constructor/components/elements/Video.vue +79 -0
- package/src/modules/constructor/components/elements/VideoPlayer.vue +59 -0
- package/src/modules/constructor/components/elements/Youtube.vue +52 -0
- package/src/modules/constructor/components/sections/Constructor.vue +27 -3
- package/src/modules/events/components/layouts/layoutEvents.vue +7 -28
- package/src/modules/files/controllers/files.controller.js +9 -22
- package/src/modules/files/middlewares/server/index.js +2 -2
- package/src/modules/files/middlewares/server/middlewareBusboy.js +137 -0
- package/src/modules/files/routes/files.routes.js +9 -9
- package/src/modules/globals/localization/vue-i18n.js +8 -1
- package/src/modules/globals/mixins/mixins.js +23 -13
- package/src/modules/globals/router/routerGuards.js +2 -2
- package/src/modules/globals/store/globals.js +86 -9
- package/src/modules/globals/utils/mailing.js +24 -3
- package/src/modules/icons/entities/IconCommunity.vue +4 -4
- package/src/modules/icons/entities/IconEvents.vue +1 -1
- package/src/modules/icons/entities/IconGroups.vue +1 -1
- package/src/modules/icons/entities/IconPrice.vue +5 -0
- package/src/modules/icons/entities/IconProfile.vue +5 -0
- package/src/modules/icons/entities/IconShopcart.vue +5 -0
- package/src/modules/icons/entities/IconTime.vue +5 -0
- package/src/modules/icons/icons.client.js +4 -0
- package/src/modules/icons/labels/LabelAppStore.vue +24 -24
- package/src/modules/icons/labels/LabelGooglePlay.vue +9 -9
- package/src/modules/icons/logos/Logotype.vue +20 -0
- package/src/modules/icons/navigation/IconAdd.vue +17 -0
- package/src/modules/icons/navigation/IconChevronBottom.vue +18 -0
- package/src/modules/icons/navigation/IconChevronRight.vue +3 -3
- package/src/modules/icons/navigation/IconDelete.vue +19 -0
- package/src/modules/icons/navigation/IconMinus.vue +15 -0
- package/src/modules/icons/navigation/IconSearch.vue +17 -0
- package/src/modules/icons/navigation/IconUpload.vue +16 -0
- package/src/modules/icons/placeholders/PlaceholderImage.vue +5 -0
- package/src/modules/icons/placeholders/PlaceholderOrganizationPic.vue +20 -0
- package/src/modules/icons/placeholders/PlaceholderUserpic.vue +4 -18
- package/src/modules/icons/socials/instagram.vue +1 -1
- package/src/modules/icons/socials/line.vue +1 -1
- package/src/modules/icons/socials/reddit.vue +1 -1
- package/src/modules/icons/socials/telegram.vue +1 -1
- package/src/modules/icons/socials/twitter.vue +1 -1
- package/src/modules/icons/socials/youtube.vue +1 -1
- package/src/modules/landing/components/sections/Guide.vue +92 -0
- package/src/modules/landing/components/sections/MobileApp.vue +23 -12
- package/src/modules/marketplace/components/layouts/Marketplace.vue +76 -188
- package/src/modules/marketplace/components/pages/Catalog.vue +65 -119
- package/src/modules/marketplace/components/sections/Filters.vue +195 -0
- package/src/modules/marketplace/store/marketplace.js +2 -2
- package/src/modules/middlewares/client/auth.validation.js +0 -6
- package/src/modules/middlewares/client/states.validation.js +2 -8
- package/src/modules/middlewares/server/authJwt.js +1 -1
- package/src/modules/mobile/components/Menu/MenuItem.vue +3 -6
- package/src/modules/openai/controllers/openai.controller.js +0 -1
- package/src/modules/orders/components/blocks/CardOrder.vue +166 -0
- package/src/modules/orders/components/blocks/CardOrderItem.vue +59 -66
- package/src/modules/orders/components/blocks/Positions.vue +4 -4
- package/src/modules/orders/components/pages/EditOrder.vue +78 -142
- package/src/modules/orders/components/pages/FormOrder.vue +192 -0
- package/src/modules/orders/components/pages/Order.vue +326 -120
- package/src/modules/orders/components/pages/Orders.vue +13 -9
- package/src/modules/orders/components/pages/{ViewOrder.vue → Orders_refact.vue} +13 -10
- package/src/modules/orders/components/partials/ShopCart.vue +22 -13
- package/src/modules/orders/components/sections/EmptyState.vue +1 -1
- package/src/modules/orders/components/sections/{Form.vue → FormOrderDetails.vue} +38 -106
- package/src/modules/orders/controllers/orders.controller.js +37 -28
- package/src/modules/orders/models/order.model.js +39 -9
- package/src/modules/orders/router/orders.router.js +23 -2
- package/src/modules/orders/routes/orders.routes.js +14 -17
- package/src/modules/orders/store/orders.js +24 -9
- package/src/modules/orders/store/shopcart.js +20 -19
- package/src/modules/organizations/components/blocks/CardDepartment.vue +1 -1
- package/src/modules/organizations/components/blocks/CardOrganization.vue +98 -46
- package/src/modules/organizations/components/blocks/Rating.vue +1 -1
- package/src/modules/organizations/components/blocks/Socials.vue +11 -3
- package/src/modules/organizations/components/elements/ButtonToggleMembership.vue +1 -1
- package/src/modules/organizations/components/pages/Department.vue +1 -1
- package/src/modules/organizations/components/pages/DepartmentEdit.vue +4 -4
- package/src/modules/organizations/components/pages/Members.vue +6 -4
- package/src/modules/organizations/components/pages/Organization.vue +120 -49
- package/src/modules/organizations/components/pages/OrganizationEdit.vue +8 -1
- package/src/modules/organizations/components/pages/Organizations.vue +27 -6
- package/src/modules/organizations/components/sections/DetailsTab.vue +11 -9
- package/src/modules/organizations/components/sections/Feed.vue +0 -3
- package/src/modules/organizations/components/sections/FeedDepartments.vue +2 -2
- package/src/modules/organizations/controllers/organizations.controller.js +126 -15
- package/src/modules/organizations/controllers/utils/addMembersQuantity.js +19 -9
- package/src/modules/organizations/models/organization.model.js +5 -2
- package/src/modules/organizations/router/members.router.js +1 -3
- package/src/modules/organizations/router/organizations.js +8 -6
- package/src/modules/organizations/router/products.router.js +36 -2
- package/src/modules/organizations/store/organizations.js +38 -84
- package/src/modules/pages/controllers/pages.controller.js +0 -4
- package/src/modules/payments/controller/payments.controller.js +1 -1
- package/src/modules/products/components/blocks/CardLeftover.vue +17 -22
- package/src/modules/products/components/blocks/CardPosition.vue +96 -49
- package/src/modules/products/components/blocks/CardProduct.vue +24 -53
- package/src/modules/products/components/blocks/Images360.vue +4 -4
- package/src/modules/products/components/blocks/ImagesThumbnails.vue +2 -7
- package/src/modules/products/components/blocks/ListPositions.vue +74 -0
- package/src/modules/products/components/elements/Price.vue +11 -5
- package/src/modules/products/components/elements/THC.vue +6 -6
- package/src/modules/products/components/pages/{LeftoverAdd.vue → EditLeftover.vue} +93 -79
- package/src/modules/products/components/pages/Leftovers.vue +74 -70
- package/src/modules/products/components/pages/Product.vue +4 -7
- package/src/modules/products/components/pages/ProductEdit.vue +230 -88
- package/src/modules/products/components/pages/ProductRecommmendation.vue +1 -1
- package/src/modules/products/components/pages/Products.vue +6 -3
- package/src/modules/products/components/pages/ProductsBackoffice.vue +3 -5
- package/src/modules/products/components/sections/EditModifications.vue +3 -3
- package/src/modules/products/components/sections/EditProductInfo.vue +40 -50
- package/src/modules/products/components/sections/FilterProducts.vue +57 -18
- package/src/modules/products/components/sections/HeroRecommendation.vue +233 -99
- package/src/modules/products/components/sections/MenuSection.vue +127 -0
- package/src/modules/products/components/sections/PopularProducts.vue +81 -37
- package/src/modules/products/components/sections/SectionProduct.vue +21 -23
- package/src/modules/products/controllers/leftovers.controller.js +11 -1
- package/src/modules/products/controllers/products.controller.js +100 -97
- package/src/modules/products/models/leftover.model.js +6 -4
- package/src/modules/products/models/product.model.js +13 -1
- package/src/modules/products/routes/products.routes.js +4 -4
- package/src/modules/products/store/leftovers.js +4 -24
- package/src/modules/products/store/products.js +44 -30
- package/src/modules/spots/components/blocks/CardSpot.vue +43 -72
- package/src/modules/spots/components/layouts/Spots.vue +9 -91
- package/src/modules/spots/components/pages/Map.vue +171 -62
- package/src/modules/spots/components/pages/Spot.vue +1 -1
- package/src/modules/spots/components/pages/SpotEdit.vue +131 -174
- package/src/modules/spots/controllers/spots.controller.js +1 -0
- package/src/modules/spots/models/spot.model.js +6 -3
- package/src/modules/spots/store/spots.js +42 -48
- package/src/modules/users/components/pages/Profile.vue +6 -28
- package/src/modules/users/components/pages/ProfileBlogposts.vue +1 -1
- package/src/modules/users/components/pages/ProfileEdit.vue +1 -1
- package/src/modules/users/components/pages/ProfileEvents.vue +1 -1
- package/src/modules/users/components/pages/ProfileOrganizations.vue +1 -1
- package/src/modules/users/router/users.js +1 -1
- package/src/modules/wallet/components/pages/Wallet.vue +105 -109
- package/src/modules/wallet/controllers/crypto.controller.js +129 -0
- package/src/modules/wallet/models/reward.model.js +53 -0
- package/src/modules/wallet/routes/crypto.routes.js +36 -0
- package/src/modules/wallet/store/wallet.js +52 -49
- package/src/styles/base/all.scss +144 -12
- package/src/styles/base/backgrounds.scss +2 -34
- package/src/styles/base/borders.scss +18 -23
- package/src/styles/base/scrolling.scss +97 -29
- package/src/styles/base/{shadows.scss → shadow_transitions_hover_refactor.scss} +55 -2
- package/src/styles/config.scss +69 -17
- package/src/styles/layout.scss +12 -182
- package/src/styles/reset.scss +20 -21
- package/src/styles/responsive.scss +4 -67
- package/src/styles/theme.scss +3 -4
- package/src/styles/typography.scss +15 -17
- package/src/assets/fonts/AvenirNext-Bold.woff2 +0 -0
- package/src/assets/fonts/AvenirNext-DemiBold.woff2 +0 -0
- package/src/assets/fonts/AvenirNext-Heavy.woff2 +0 -0
- package/src/assets/fonts/AvenirNext-Medium.woff2 +0 -0
- package/src/assets/fonts/AvenirNext-Regular.woff2 +0 -0
- package/src/assets/fonts/AvenirNext-UltraLight.woff2 +0 -0
- package/src/modules/files/middlewares/server/md.js +0 -152
- package/src/modules/files/middlewares/server/middlewareMulter.js +0 -121
- package/src/modules/organizations/controllers/organizations.new.controller.js +0 -372
- package/src/modules/products/components/blocks/EditCategories.vue +0 -68
- package/src/modules/products/components/sections/EditParameters.vue +0 -58
- package/src/modules/products/components/sections/EditProductImages.vue +0 -67
- package/src/modules/spots/components/sections/Feed.vue +0 -64
- package/src/styles/base/border-radius.scss +0 -47
- package/src/styles/base/cursors.scss +0 -23
- package/src/styles/base/height.scss +0 -60
- package/src/styles/base/hovers.scss +0 -110
- package/src/styles/base/positions.scss +0 -192
- package/src/styles/base/transitions.scss +0 -137
- package/src/styles/base/width.scss +0 -2
- package/src/styles/components/block.scss +0 -18
- package/src/styles/components/breadcrumbs.scss +0 -0
- package/src/styles/components/input.scss +0 -319
@@ -1,5 +1,5 @@
|
|
1
1
|
import { g as getDefaultExportFromCjs } from "./_commonjsHelpers-83b1d755.mjs";
|
2
|
-
import { v as verifyUser$1, a as verifyInvites$1, b as authJwt$1, c as verifySignUp$1, d as verifyCategory$1, s as server } from "./index-
|
2
|
+
import { v as verifyUser$1, a as verifyInvites$1, b as authJwt$1, c as verifySignUp$1, d as verifyCategory$1, s as server } from "./index-d769324d.mjs";
|
3
3
|
import "jsonwebtoken";
|
4
4
|
import "mongodb";
|
5
5
|
const verifyUser = verifyUser$1;
|
@@ -6,8 +6,8 @@ require("bcryptjs");
|
|
6
6
|
require("uuidv4");
|
7
7
|
const require$$0 = require("mongoose");
|
8
8
|
const require$$5 = require("@googlemaps/google-maps-services-js");
|
9
|
-
const addMembersQuantity$1 = require("./addMembersQuantity-
|
10
|
-
require("mongodb");
|
9
|
+
const addMembersQuantity$1 = require("./addMembersQuantity-fb552ca0.js");
|
10
|
+
const require$$0$2 = require("mongodb");
|
11
11
|
const controllerFactory$5 = (db) => {
|
12
12
|
const Department = db.department;
|
13
13
|
const readOne = (req, res) => {
|
@@ -72,7 +72,7 @@ const controllerFactory$5 = (db) => {
|
|
72
72
|
};
|
73
73
|
var departments_controller = controllerFactory$5;
|
74
74
|
const jwt = require$$0$1;
|
75
|
-
const ObjectId = require$$0.Types.ObjectId;
|
75
|
+
const ObjectId$1 = require$$0.Types.ObjectId;
|
76
76
|
const { Client } = require$$5;
|
77
77
|
const client = new Client({});
|
78
78
|
const addUserStatusFields = addMembersQuantity$1.addUserStatusFields_1;
|
@@ -87,10 +87,10 @@ const controllerFactory$4 = (db) => {
|
|
87
87
|
db.membership;
|
88
88
|
db.user;
|
89
89
|
db.role;
|
90
|
-
console.log(req);
|
91
90
|
const sortParam = req.query.sortParam || "numberOfProducts";
|
92
91
|
const sortOrder = req.query.sortOrder || "desc";
|
93
92
|
const sort = {
|
93
|
+
"numberOfProducts": -1,
|
94
94
|
[sortParam]: sortOrder === "desc" ? -1 : 1,
|
95
95
|
"_id": 1
|
96
96
|
};
|
@@ -109,23 +109,30 @@ const controllerFactory$4 = (db) => {
|
|
109
109
|
const [min, max] = priceRange.split("-").map(Number);
|
110
110
|
return { "products.price": { $gte: min, $lte: max } };
|
111
111
|
});
|
112
|
-
|
112
|
+
let containConditions = [];
|
113
|
+
if (req.query.contain) {
|
114
|
+
containConditions = req.query.contain.map((property) => ({
|
115
|
+
[property]: { $exists: true, $not: { $size: 0 } }
|
116
|
+
}));
|
117
|
+
}
|
113
118
|
const matchConditions = [
|
114
|
-
...req.query._id ? [{ _id: new ObjectId(req.query._id) }] : [],
|
115
|
-
...req.query.owner ? [{ owner: new ObjectId(req.query.owner) }] : [],
|
116
|
-
...req.query.member ? [{ "memberships.user": new ObjectId(req.query.member), "memberships.role": { $
|
117
|
-
...req.query.subscriber ? [{ "memberships.user": new ObjectId(req.query.subscriber), "memberships.role": "subscriber" }] : [],
|
118
|
-
...req.query.postable ? [{ $or: [{ $and: [{ types: { $elemMatch: { $eq: "public" } } }, { "memberships.user": new ObjectId(req.query.postable) }] }, { $and: [{ types: { $elemMatch: { $in: ["exclusive", "hidden"] } } }, { "memberships.user": new ObjectId(req.query.postable) }, { "memberships.role": { $ne: "subscriber" } }] }] }] : [],
|
119
|
+
...req.query._id ? [{ _id: new ObjectId$1(req.query._id) }] : [],
|
120
|
+
...req.query.owner ? [{ owner: new ObjectId$1(req.query.owner) }] : [],
|
121
|
+
...req.query.member ? [{ "memberships.user": new ObjectId$1(req.query.member), "memberships.role": { $nin: ["subscriber", "owner"] } }] : [],
|
122
|
+
...req.query.subscriber ? [{ "memberships.user": new ObjectId$1(req.query.subscriber), "memberships.role": "subscriber" }] : [],
|
123
|
+
...req.query.postable ? [{ $or: [{ $and: [{ types: { $elemMatch: { $eq: "public" } } }, { "memberships.user": new ObjectId$1(req.query.postable) }] }, { $and: [{ types: { $elemMatch: { $in: ["exclusive", "hidden"] } } }, { "memberships.user": new ObjectId$1(req.query.postable) }, { "memberships.role": { $ne: "subscriber" } }] }] }] : [],
|
119
124
|
...req.query.types ? [{ types: { $in: req.query.types } }] : [],
|
120
125
|
// Если req.query.types - строка
|
121
126
|
// to remove
|
122
|
-
...req.query.onlyuser ? [{ "memberships.user": new ObjectId(req.query.onlyuser) }] : [],
|
127
|
+
...req.query.onlyuser ? [{ "memberships.user": new ObjectId$1(req.query.onlyuser) }] : [],
|
123
128
|
...categories.length > 0 ? [{ "products.category": { $in: categories } }] : [],
|
124
|
-
...delivery.length > 0 ? [{ "
|
125
|
-
...priceConditions.length > 0 ? [{ $or: priceConditions }] : []
|
129
|
+
...delivery.length > 0 ? [{ "spots.delivery": { $all: delivery } }] : [],
|
130
|
+
...priceConditions.length > 0 ? [{ $or: priceConditions }] : [],
|
131
|
+
...req.query.contain ? containConditions : []
|
126
132
|
];
|
127
|
-
let { location, address, city, state, country } = req.query;
|
128
|
-
|
133
|
+
let { location, address, locationRadius, city, state, country } = req.query;
|
134
|
+
let userLocation = { coordinates: [0, 0] };
|
135
|
+
if (!location && (address || city || state || country)) {
|
129
136
|
let geoLocation;
|
130
137
|
const searchString = [address, city, state, country].filter(Boolean).join(", ");
|
131
138
|
try {
|
@@ -137,6 +144,11 @@ const controllerFactory$4 = (db) => {
|
|
137
144
|
});
|
138
145
|
if (geoResponse.data.results && geoResponse.data.results.length > 0) {
|
139
146
|
geoLocation = geoResponse.data.results[0].geometry.location;
|
147
|
+
userLocation.coordinates = [
|
148
|
+
geoResponse.data.results[0].geometry.location.lng,
|
149
|
+
geoResponse.data.results[0].geometry.location.lat
|
150
|
+
];
|
151
|
+
console.log(userLocation);
|
140
152
|
} else {
|
141
153
|
return res.status(400).send({ message: "Unable to geocode the provided location." });
|
142
154
|
}
|
@@ -144,30 +156,56 @@ const controllerFactory$4 = (db) => {
|
|
144
156
|
console.log(err);
|
145
157
|
return res.status(500).send({ message: "Error occurred while geocoding." });
|
146
158
|
}
|
147
|
-
const radius = city ?
|
159
|
+
const radius = city ? 500 : state ? 1e3 : 5e3;
|
148
160
|
matchConditions.push({
|
149
|
-
"
|
161
|
+
"spots.location.coordinates": {
|
150
162
|
$geoWithin: {
|
151
163
|
$centerSphere: [
|
152
|
-
[geoLocation.lng, geoLocation.lat],
|
164
|
+
[parseFloat(geoLocation.lng), parseFloat(geoLocation.lat)],
|
153
165
|
radius / 6378.1
|
154
166
|
]
|
155
167
|
}
|
156
168
|
}
|
157
169
|
});
|
158
170
|
}
|
171
|
+
const search = req.query.search;
|
172
|
+
if (search) {
|
173
|
+
const parts = search.split(".");
|
174
|
+
let regexPattern = "";
|
175
|
+
if (parts.length === 2) {
|
176
|
+
regexPattern = parts.map((part) => part.substr(0, part.length - 1) + ".{1}").join("\\.");
|
177
|
+
} else {
|
178
|
+
regexPattern = search.substr(0, search.length - 1) + ".{1}";
|
179
|
+
}
|
180
|
+
matchConditions.push({
|
181
|
+
$or: [
|
182
|
+
{ "profile.name": { $regex: regexPattern, $options: "i" } },
|
183
|
+
{ "products.name": { $regex: regexPattern, $options: "i" } }
|
184
|
+
]
|
185
|
+
});
|
186
|
+
}
|
159
187
|
if (location) {
|
160
|
-
console.log(
|
188
|
+
console.log(location);
|
161
189
|
if (typeof location === "string") {
|
162
190
|
location = JSON.parse(location);
|
163
191
|
}
|
164
|
-
let
|
192
|
+
let lng;
|
193
|
+
let lat;
|
194
|
+
if (location.lng) {
|
195
|
+
lng = location.lng;
|
196
|
+
lat = location.lat;
|
197
|
+
userLocation.coordinates = [lng, lat];
|
198
|
+
} else {
|
199
|
+
lng = location.coordinates[0];
|
200
|
+
lat = location.coordinates[1];
|
201
|
+
userLocation.coordinates = [lng, lat];
|
202
|
+
}
|
165
203
|
matchConditions.push({
|
166
|
-
"
|
204
|
+
"spots.location.coordinates": {
|
167
205
|
$geoWithin: {
|
168
206
|
$centerSphere: [
|
169
|
-
[lng, lat],
|
170
|
-
|
207
|
+
[parseFloat(lng), parseFloat(lat)],
|
208
|
+
(locationRadius || 50) / 6378.1
|
171
209
|
]
|
172
210
|
}
|
173
211
|
}
|
@@ -183,6 +221,14 @@ const controllerFactory$4 = (db) => {
|
|
183
221
|
as: "products"
|
184
222
|
}
|
185
223
|
},
|
224
|
+
{
|
225
|
+
$lookup: {
|
226
|
+
from: "blogposts",
|
227
|
+
localField: "_id",
|
228
|
+
foreignField: "owner.target",
|
229
|
+
as: "blogposts"
|
230
|
+
}
|
231
|
+
},
|
186
232
|
{
|
187
233
|
$addFields: {
|
188
234
|
numberOfProducts: { $size: "$products" }
|
@@ -204,6 +250,58 @@ const controllerFactory$4 = (db) => {
|
|
204
250
|
as: "spots"
|
205
251
|
}
|
206
252
|
},
|
253
|
+
{
|
254
|
+
$addFields: {
|
255
|
+
spots: {
|
256
|
+
$map: {
|
257
|
+
input: "$spots",
|
258
|
+
as: "spot",
|
259
|
+
in: {
|
260
|
+
$mergeObjects: [
|
261
|
+
"$$spot",
|
262
|
+
{
|
263
|
+
distance: {
|
264
|
+
$function: {
|
265
|
+
body: `function(spotCoords, userCoords, isMiles) {
|
266
|
+
// The function remains the same
|
267
|
+
function toRad(x) {
|
268
|
+
return x * Math.PI / 180;
|
269
|
+
}
|
270
|
+
var lon1 = spotCoords[0];
|
271
|
+
var lat1 = spotCoords[1];
|
272
|
+
var lon2 = userCoords[0];
|
273
|
+
var lat2 = userCoords[1];
|
274
|
+
var R = 6371; // Radius of the Earth in km
|
275
|
+
if (isMiles) R = 3959; // Radius of the Earth in miles
|
276
|
+
var x1 = lat2 - lat1;
|
277
|
+
var dLat = toRad(x1);
|
278
|
+
var x2 = lon2 - lon1;
|
279
|
+
var dLon = toRad(x2);
|
280
|
+
var a = Math.sin(dLat / 2) * Math.sin(dLat / 2) +
|
281
|
+
Math.cos(toRad(lat1)) * Math.cos(toRad(lat2)) *
|
282
|
+
Math.sin(dLon / 2) * Math.sin(dLon / 2);
|
283
|
+
var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
|
284
|
+
var d = R * c;
|
285
|
+
return d;
|
286
|
+
}`,
|
287
|
+
args: ["$$spot.location.coordinates", userLocation.coordinates, false],
|
288
|
+
// Use actual field names
|
289
|
+
lang: "js"
|
290
|
+
}
|
291
|
+
}
|
292
|
+
}
|
293
|
+
]
|
294
|
+
}
|
295
|
+
}
|
296
|
+
}
|
297
|
+
}
|
298
|
+
},
|
299
|
+
{
|
300
|
+
$addFields: {
|
301
|
+
distance: { $min: "$spots.distance" }
|
302
|
+
// Add the minDistance field here
|
303
|
+
}
|
304
|
+
},
|
207
305
|
{
|
208
306
|
$lookup: {
|
209
307
|
from: "memberships",
|
@@ -545,11 +643,12 @@ var department_model = (mongoose) => {
|
|
545
643
|
const Department = mongoose.model("Department", departmentSchema);
|
546
644
|
return Department;
|
547
645
|
};
|
646
|
+
const { ObjectId } = require$$0$2;
|
548
647
|
var organization_model = (mongoose) => {
|
549
648
|
const OrganizationSchema = new mongoose.Schema({
|
550
649
|
// Creator and owner of organizations
|
551
650
|
owner: {
|
552
|
-
type:
|
651
|
+
type: ObjectId,
|
553
652
|
ref: "User",
|
554
653
|
required: true
|
555
654
|
},
|
@@ -586,7 +685,8 @@ var organization_model = (mongoose) => {
|
|
586
685
|
telegram: String,
|
587
686
|
twitter: String,
|
588
687
|
facebook: String,
|
589
|
-
instagram: String
|
688
|
+
instagram: String,
|
689
|
+
youtube: String
|
590
690
|
},
|
591
691
|
// departments
|
592
692
|
structure: {
|
@@ -5,8 +5,8 @@ import "bcryptjs";
|
|
5
5
|
import "uuidv4";
|
6
6
|
import require$$0 from "mongoose";
|
7
7
|
import require$$5 from "@googlemaps/google-maps-services-js";
|
8
|
-
import { a as addUserStatusFields_1, b as addMembersQuantity_1 } from "./addMembersQuantity-
|
9
|
-
import "mongodb";
|
8
|
+
import { a as addUserStatusFields_1, b as addMembersQuantity_1 } from "./addMembersQuantity-3505b6f3.mjs";
|
9
|
+
import require$$0$2 from "mongodb";
|
10
10
|
const controllerFactory$5 = (db) => {
|
11
11
|
const Department = db.department;
|
12
12
|
const readOne = (req, res) => {
|
@@ -71,7 +71,7 @@ const controllerFactory$5 = (db) => {
|
|
71
71
|
};
|
72
72
|
var departments_controller = controllerFactory$5;
|
73
73
|
const jwt = require$$0$1;
|
74
|
-
const ObjectId = require$$0.Types.ObjectId;
|
74
|
+
const ObjectId$1 = require$$0.Types.ObjectId;
|
75
75
|
const { Client } = require$$5;
|
76
76
|
const client = new Client({});
|
77
77
|
const addUserStatusFields = addUserStatusFields_1;
|
@@ -86,10 +86,10 @@ const controllerFactory$4 = (db) => {
|
|
86
86
|
db.membership;
|
87
87
|
db.user;
|
88
88
|
db.role;
|
89
|
-
console.log(req);
|
90
89
|
const sortParam = req.query.sortParam || "numberOfProducts";
|
91
90
|
const sortOrder = req.query.sortOrder || "desc";
|
92
91
|
const sort = {
|
92
|
+
"numberOfProducts": -1,
|
93
93
|
[sortParam]: sortOrder === "desc" ? -1 : 1,
|
94
94
|
"_id": 1
|
95
95
|
};
|
@@ -108,23 +108,30 @@ const controllerFactory$4 = (db) => {
|
|
108
108
|
const [min, max] = priceRange.split("-").map(Number);
|
109
109
|
return { "products.price": { $gte: min, $lte: max } };
|
110
110
|
});
|
111
|
-
|
111
|
+
let containConditions = [];
|
112
|
+
if (req.query.contain) {
|
113
|
+
containConditions = req.query.contain.map((property) => ({
|
114
|
+
[property]: { $exists: true, $not: { $size: 0 } }
|
115
|
+
}));
|
116
|
+
}
|
112
117
|
const matchConditions = [
|
113
|
-
...req.query._id ? [{ _id: new ObjectId(req.query._id) }] : [],
|
114
|
-
...req.query.owner ? [{ owner: new ObjectId(req.query.owner) }] : [],
|
115
|
-
...req.query.member ? [{ "memberships.user": new ObjectId(req.query.member), "memberships.role": { $
|
116
|
-
...req.query.subscriber ? [{ "memberships.user": new ObjectId(req.query.subscriber), "memberships.role": "subscriber" }] : [],
|
117
|
-
...req.query.postable ? [{ $or: [{ $and: [{ types: { $elemMatch: { $eq: "public" } } }, { "memberships.user": new ObjectId(req.query.postable) }] }, { $and: [{ types: { $elemMatch: { $in: ["exclusive", "hidden"] } } }, { "memberships.user": new ObjectId(req.query.postable) }, { "memberships.role": { $ne: "subscriber" } }] }] }] : [],
|
118
|
+
...req.query._id ? [{ _id: new ObjectId$1(req.query._id) }] : [],
|
119
|
+
...req.query.owner ? [{ owner: new ObjectId$1(req.query.owner) }] : [],
|
120
|
+
...req.query.member ? [{ "memberships.user": new ObjectId$1(req.query.member), "memberships.role": { $nin: ["subscriber", "owner"] } }] : [],
|
121
|
+
...req.query.subscriber ? [{ "memberships.user": new ObjectId$1(req.query.subscriber), "memberships.role": "subscriber" }] : [],
|
122
|
+
...req.query.postable ? [{ $or: [{ $and: [{ types: { $elemMatch: { $eq: "public" } } }, { "memberships.user": new ObjectId$1(req.query.postable) }] }, { $and: [{ types: { $elemMatch: { $in: ["exclusive", "hidden"] } } }, { "memberships.user": new ObjectId$1(req.query.postable) }, { "memberships.role": { $ne: "subscriber" } }] }] }] : [],
|
118
123
|
...req.query.types ? [{ types: { $in: req.query.types } }] : [],
|
119
124
|
// Если req.query.types - строка
|
120
125
|
// to remove
|
121
|
-
...req.query.onlyuser ? [{ "memberships.user": new ObjectId(req.query.onlyuser) }] : [],
|
126
|
+
...req.query.onlyuser ? [{ "memberships.user": new ObjectId$1(req.query.onlyuser) }] : [],
|
122
127
|
...categories.length > 0 ? [{ "products.category": { $in: categories } }] : [],
|
123
|
-
...delivery.length > 0 ? [{ "
|
124
|
-
...priceConditions.length > 0 ? [{ $or: priceConditions }] : []
|
128
|
+
...delivery.length > 0 ? [{ "spots.delivery": { $all: delivery } }] : [],
|
129
|
+
...priceConditions.length > 0 ? [{ $or: priceConditions }] : [],
|
130
|
+
...req.query.contain ? containConditions : []
|
125
131
|
];
|
126
|
-
let { location, address, city, state, country } = req.query;
|
127
|
-
|
132
|
+
let { location, address, locationRadius, city, state, country } = req.query;
|
133
|
+
let userLocation = { coordinates: [0, 0] };
|
134
|
+
if (!location && (address || city || state || country)) {
|
128
135
|
let geoLocation;
|
129
136
|
const searchString = [address, city, state, country].filter(Boolean).join(", ");
|
130
137
|
try {
|
@@ -136,6 +143,11 @@ const controllerFactory$4 = (db) => {
|
|
136
143
|
});
|
137
144
|
if (geoResponse.data.results && geoResponse.data.results.length > 0) {
|
138
145
|
geoLocation = geoResponse.data.results[0].geometry.location;
|
146
|
+
userLocation.coordinates = [
|
147
|
+
geoResponse.data.results[0].geometry.location.lng,
|
148
|
+
geoResponse.data.results[0].geometry.location.lat
|
149
|
+
];
|
150
|
+
console.log(userLocation);
|
139
151
|
} else {
|
140
152
|
return res.status(400).send({ message: "Unable to geocode the provided location." });
|
141
153
|
}
|
@@ -143,30 +155,56 @@ const controllerFactory$4 = (db) => {
|
|
143
155
|
console.log(err);
|
144
156
|
return res.status(500).send({ message: "Error occurred while geocoding." });
|
145
157
|
}
|
146
|
-
const radius = city ?
|
158
|
+
const radius = city ? 500 : state ? 1e3 : 5e3;
|
147
159
|
matchConditions.push({
|
148
|
-
"
|
160
|
+
"spots.location.coordinates": {
|
149
161
|
$geoWithin: {
|
150
162
|
$centerSphere: [
|
151
|
-
[geoLocation.lng, geoLocation.lat],
|
163
|
+
[parseFloat(geoLocation.lng), parseFloat(geoLocation.lat)],
|
152
164
|
radius / 6378.1
|
153
165
|
]
|
154
166
|
}
|
155
167
|
}
|
156
168
|
});
|
157
169
|
}
|
170
|
+
const search = req.query.search;
|
171
|
+
if (search) {
|
172
|
+
const parts = search.split(".");
|
173
|
+
let regexPattern = "";
|
174
|
+
if (parts.length === 2) {
|
175
|
+
regexPattern = parts.map((part) => part.substr(0, part.length - 1) + ".{1}").join("\\.");
|
176
|
+
} else {
|
177
|
+
regexPattern = search.substr(0, search.length - 1) + ".{1}";
|
178
|
+
}
|
179
|
+
matchConditions.push({
|
180
|
+
$or: [
|
181
|
+
{ "profile.name": { $regex: regexPattern, $options: "i" } },
|
182
|
+
{ "products.name": { $regex: regexPattern, $options: "i" } }
|
183
|
+
]
|
184
|
+
});
|
185
|
+
}
|
158
186
|
if (location) {
|
159
|
-
console.log(
|
187
|
+
console.log(location);
|
160
188
|
if (typeof location === "string") {
|
161
189
|
location = JSON.parse(location);
|
162
190
|
}
|
163
|
-
let
|
191
|
+
let lng;
|
192
|
+
let lat;
|
193
|
+
if (location.lng) {
|
194
|
+
lng = location.lng;
|
195
|
+
lat = location.lat;
|
196
|
+
userLocation.coordinates = [lng, lat];
|
197
|
+
} else {
|
198
|
+
lng = location.coordinates[0];
|
199
|
+
lat = location.coordinates[1];
|
200
|
+
userLocation.coordinates = [lng, lat];
|
201
|
+
}
|
164
202
|
matchConditions.push({
|
165
|
-
"
|
203
|
+
"spots.location.coordinates": {
|
166
204
|
$geoWithin: {
|
167
205
|
$centerSphere: [
|
168
|
-
[lng, lat],
|
169
|
-
|
206
|
+
[parseFloat(lng), parseFloat(lat)],
|
207
|
+
(locationRadius || 50) / 6378.1
|
170
208
|
]
|
171
209
|
}
|
172
210
|
}
|
@@ -182,6 +220,14 @@ const controllerFactory$4 = (db) => {
|
|
182
220
|
as: "products"
|
183
221
|
}
|
184
222
|
},
|
223
|
+
{
|
224
|
+
$lookup: {
|
225
|
+
from: "blogposts",
|
226
|
+
localField: "_id",
|
227
|
+
foreignField: "owner.target",
|
228
|
+
as: "blogposts"
|
229
|
+
}
|
230
|
+
},
|
185
231
|
{
|
186
232
|
$addFields: {
|
187
233
|
numberOfProducts: { $size: "$products" }
|
@@ -203,6 +249,58 @@ const controllerFactory$4 = (db) => {
|
|
203
249
|
as: "spots"
|
204
250
|
}
|
205
251
|
},
|
252
|
+
{
|
253
|
+
$addFields: {
|
254
|
+
spots: {
|
255
|
+
$map: {
|
256
|
+
input: "$spots",
|
257
|
+
as: "spot",
|
258
|
+
in: {
|
259
|
+
$mergeObjects: [
|
260
|
+
"$$spot",
|
261
|
+
{
|
262
|
+
distance: {
|
263
|
+
$function: {
|
264
|
+
body: `function(spotCoords, userCoords, isMiles) {
|
265
|
+
// The function remains the same
|
266
|
+
function toRad(x) {
|
267
|
+
return x * Math.PI / 180;
|
268
|
+
}
|
269
|
+
var lon1 = spotCoords[0];
|
270
|
+
var lat1 = spotCoords[1];
|
271
|
+
var lon2 = userCoords[0];
|
272
|
+
var lat2 = userCoords[1];
|
273
|
+
var R = 6371; // Radius of the Earth in km
|
274
|
+
if (isMiles) R = 3959; // Radius of the Earth in miles
|
275
|
+
var x1 = lat2 - lat1;
|
276
|
+
var dLat = toRad(x1);
|
277
|
+
var x2 = lon2 - lon1;
|
278
|
+
var dLon = toRad(x2);
|
279
|
+
var a = Math.sin(dLat / 2) * Math.sin(dLat / 2) +
|
280
|
+
Math.cos(toRad(lat1)) * Math.cos(toRad(lat2)) *
|
281
|
+
Math.sin(dLon / 2) * Math.sin(dLon / 2);
|
282
|
+
var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
|
283
|
+
var d = R * c;
|
284
|
+
return d;
|
285
|
+
}`,
|
286
|
+
args: ["$$spot.location.coordinates", userLocation.coordinates, false],
|
287
|
+
// Use actual field names
|
288
|
+
lang: "js"
|
289
|
+
}
|
290
|
+
}
|
291
|
+
}
|
292
|
+
]
|
293
|
+
}
|
294
|
+
}
|
295
|
+
}
|
296
|
+
}
|
297
|
+
},
|
298
|
+
{
|
299
|
+
$addFields: {
|
300
|
+
distance: { $min: "$spots.distance" }
|
301
|
+
// Add the minDistance field here
|
302
|
+
}
|
303
|
+
},
|
206
304
|
{
|
207
305
|
$lookup: {
|
208
306
|
from: "memberships",
|
@@ -544,11 +642,12 @@ var department_model = (mongoose) => {
|
|
544
642
|
const Department = mongoose.model("Department", departmentSchema);
|
545
643
|
return Department;
|
546
644
|
};
|
645
|
+
const { ObjectId } = require$$0$2;
|
547
646
|
var organization_model = (mongoose) => {
|
548
647
|
const OrganizationSchema = new mongoose.Schema({
|
549
648
|
// Creator and owner of organizations
|
550
649
|
owner: {
|
551
|
-
type:
|
650
|
+
type: ObjectId,
|
552
651
|
ref: "User",
|
553
652
|
required: true
|
554
653
|
},
|
@@ -585,7 +684,8 @@ var organization_model = (mongoose) => {
|
|
585
684
|
telegram: String,
|
586
685
|
twitter: String,
|
587
686
|
facebook: String,
|
588
|
-
instagram: String
|
687
|
+
instagram: String,
|
688
|
+
youtube: String
|
589
689
|
},
|
590
690
|
// departments
|
591
691
|
structure: {
|
@@ -1 +1 @@
|
|
1
|
-
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e="";
|
1
|
+
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("vue"),a=require("../FieldPhone/click-outside.cjs");require("./Dropdown.vue2.cjs");const u=require("../../../../_virtual/_plugin-vue_export-helper.cjs"),s={__name:"Dropdown",props:{label:{type:String,default:"Open"},align:{type:String,default:"left"}},setup(i){let n=a.default;const t=e.ref(!1);function r(){t.value=!1}return(o,l)=>e.withDirectives((e.openBlock(),e.createElementBlock("div",{class:"dropdown pos-relative",onClick:l[0]||(l[0]=e.withModifiers(c=>t.value=!t.value,["stop"]))},[e.createTextVNode(e.toDisplayString(i.label)+" ",1),e.createVNode(e.Transition,{name:"TransitionTranslateY",mode:"out-in"},{default:e.withCtx(()=>[e.withDirectives(e.createElementVNode("div",{style:e.normalizeStyle({left:i.align==="left"?"0":"auto",right:i.align==="right"?"0":"auto"}),class:"dropdown-content w-15r radius-big"},[e.renderSlot(o.$slots,"default",{},void 0,!0)],4),[[e.vShow,t.value]])]),_:3})])),[[e.unref(n),r]])}},d=u.default(s,[["__scopeId","data-v-2f59adb5"]]);exports.default=d;
|
@@ -1,4 +1,51 @@
|
|
1
|
-
|
1
|
+
import { ref as a, withDirectives as i, openBlock as d, createElementBlock as s, withModifiers as u, createTextVNode as c, toDisplayString as f, createVNode as p, Transition as m, withCtx as v, createElementVNode as g, normalizeStyle as w, renderSlot as k, vShow as S, unref as h } from "vue";
|
2
|
+
import y from "../FieldPhone/click-outside.js";
|
3
|
+
import "./Dropdown.vue2.js";
|
4
|
+
import O from "../../../../_virtual/_plugin-vue_export-helper.js";
|
5
|
+
const b = {
|
6
|
+
__name: "Dropdown",
|
7
|
+
props: {
|
8
|
+
label: {
|
9
|
+
type: String,
|
10
|
+
default: "Open"
|
11
|
+
},
|
12
|
+
align: {
|
13
|
+
type: String,
|
14
|
+
default: "left"
|
15
|
+
}
|
16
|
+
},
|
17
|
+
setup(t) {
|
18
|
+
let l = y;
|
19
|
+
const e = a(!1);
|
20
|
+
function n() {
|
21
|
+
e.value = !1;
|
22
|
+
}
|
23
|
+
return (r, o) => i((d(), s("div", {
|
24
|
+
class: "dropdown pos-relative",
|
25
|
+
onClick: o[0] || (o[0] = u((x) => e.value = !e.value, ["stop"]))
|
26
|
+
}, [
|
27
|
+
c(f(t.label) + " ", 1),
|
28
|
+
p(m, {
|
29
|
+
name: "TransitionTranslateY",
|
30
|
+
mode: "out-in"
|
31
|
+
}, {
|
32
|
+
default: v(() => [
|
33
|
+
i(g("div", {
|
34
|
+
style: w({ left: t.align === "left" ? "0" : "auto", right: t.align === "right" ? "0" : "auto" }),
|
35
|
+
class: "dropdown-content w-15r radius-big"
|
36
|
+
}, [
|
37
|
+
k(r.$slots, "default", {}, void 0, !0)
|
38
|
+
], 4), [
|
39
|
+
[S, e.value]
|
40
|
+
])
|
41
|
+
]),
|
42
|
+
_: 3
|
43
|
+
})
|
44
|
+
])), [
|
45
|
+
[h(l), n]
|
46
|
+
]);
|
47
|
+
}
|
48
|
+
}, N = /* @__PURE__ */ O(b, [["__scopeId", "data-v-2f59adb5"]]);
|
2
49
|
export {
|
3
|
-
|
50
|
+
N as default
|
4
51
|
};
|
@@ -1 +1 @@
|
|
1
|
-
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=
|
1
|
+
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e="";exports.default=e;
|
@@ -1,51 +1,4 @@
|
|
1
|
-
|
2
|
-
import y from "../FieldPhone/click-outside.js";
|
3
|
-
import "./Dropdown.vue.js";
|
4
|
-
import O from "../../../../_virtual/_plugin-vue_export-helper.js";
|
5
|
-
const b = {
|
6
|
-
__name: "Dropdown",
|
7
|
-
props: {
|
8
|
-
label: {
|
9
|
-
type: String,
|
10
|
-
default: "Open"
|
11
|
-
},
|
12
|
-
align: {
|
13
|
-
type: String,
|
14
|
-
default: "left"
|
15
|
-
}
|
16
|
-
},
|
17
|
-
setup(t) {
|
18
|
-
let l = y;
|
19
|
-
const e = a(!1);
|
20
|
-
function n() {
|
21
|
-
e.value = !1;
|
22
|
-
}
|
23
|
-
return (r, o) => i((d(), s("div", {
|
24
|
-
class: "dropdown pos-relative",
|
25
|
-
onClick: o[0] || (o[0] = u((x) => e.value = !e.value, ["stop"]))
|
26
|
-
}, [
|
27
|
-
c(f(t.label) + " ", 1),
|
28
|
-
p(m, {
|
29
|
-
name: "TransitionTranslateY",
|
30
|
-
mode: "out-in"
|
31
|
-
}, {
|
32
|
-
default: v(() => [
|
33
|
-
i(g("div", {
|
34
|
-
style: w({ left: t.align === "left" ? "0" : "auto", right: t.align === "right" ? "0" : "auto" }),
|
35
|
-
class: "dropdown-content w-15r radius-big"
|
36
|
-
}, [
|
37
|
-
k(r.$slots, "default", {}, void 0, !0)
|
38
|
-
], 4), [
|
39
|
-
[S, e.value]
|
40
|
-
])
|
41
|
-
]),
|
42
|
-
_: 3
|
43
|
-
})
|
44
|
-
])), [
|
45
|
-
[h(l), n]
|
46
|
-
]);
|
47
|
-
}
|
48
|
-
}, N = /* @__PURE__ */ O(b, [["__scopeId", "data-v-2f59adb5"]]);
|
1
|
+
const _ = "";
|
49
2
|
export {
|
50
|
-
|
3
|
+
_ as default
|
51
4
|
};
|
@@ -1 +1 @@
|
|
1
|
-
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e="";
|
1
|
+
"use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("vue");require("./Select.vue2.cjs");const p=require("../../../../_virtual/_plugin-vue_export-helper.cjs"),k=["onClick"],v={key:0,class:"t-transp mn-r-small"},f={class:"w-100"},h=["onClick"],g={key:0,class:"w-100"},B={key:0,class:"mn-t-thin invalid-feedback"},_={__name:"Select",props:{label:String,select:[String,Object],placeholder:{type:String,default:"Please select an item"},options:{type:Array,default:()=>[]},validation:Boolean},emits:["update:select","focus","blur"],setup(l,{emit:u}){const c=u,o=l,n=e.ref(o.select),a=e.ref(!1);e.watch(()=>o.select,t=>{n.value=t});const d=e.computed(()=>o.select?o.options.filter(t=>t!==o.select):o.options),r=()=>{a.value=!a.value,c(a.value?"focus":"blur")},m=t=>{n.value=t,r(),c("update:select",n.value)};return(t,C)=>{var i;return e.openBlock(),e.createElementBlock(e.Fragment,null,[e.createElementVNode("div",{onClick:e.withModifiers(r,["stop"]),class:e.normalizeClass([t.$attrs.class,"cursor-pointer flex-nowrap flex"])},[l.label?(e.openBlock(),e.createElementBlock("div",v,[e.createElementVNode("span",null,e.toDisplayString(l.label),1)])):e.createCommentVNode("",!0),e.createElementVNode("li",f,[e.createElementVNode("span",null,e.toDisplayString(((i=n.value)==null?void 0:i.name)||n.value||l.placeholder),1)]),e.createVNode(e.Transition,{mode:"out-in",name:"TransitionTranslateY"},{default:e.withCtx(()=>[a.value?(e.openBlock(),e.createElementBlock("ul",{key:0,class:e.normalizeClass([t.$attrs.class,"pos-absolute pos-t-100 pos-l-0 z-index-5 w-100 mn-t-thin"])},[(e.openBlock(!0),e.createElementBlock(e.Fragment,null,e.renderList(d.value,s=>(e.openBlock(),e.createElementBlock("li",{onClick:e.withModifiers(E=>m(s),["stop"])},[s?(e.openBlock(),e.createElementBlock("span",g,e.toDisplayString(s.name||s),1)):e.createCommentVNode("",!0)],8,h))),256))],2)):e.createCommentVNode("",!0)]),_:1})],10,k),e.createVNode(e.Transition,{mode:"out-in",name:"fade"},{default:e.withCtx(()=>[l.validation?(e.openBlock(),e.createElementBlock("div",B," * "+e.toDisplayString(l.validation.message),1)):e.createCommentVNode("",!0)]),_:1})],64)}}},y=p.default(_,[["__scopeId","data-v-dfe03dc2"]]);exports.default=y;
|