@ozdao/prometheus-framework 0.2.30 → 0.2.31

Sign up to get free protection for your applications and to get access to all the features.
Files changed (269) hide show
  1. package/dist/addMembersQuantity-3505b6f3.mjs +98 -0
  2. package/dist/addMembersQuantity-fb552ca0.js +97 -0
  3. package/dist/auth.server.js +6 -9
  4. package/dist/auth.server.mjs +6 -9
  5. package/dist/community.server.js +28 -21
  6. package/dist/community.server.mjs +28 -21
  7. package/dist/events.server.js +1 -1
  8. package/dist/events.server.mjs +1 -1
  9. package/dist/files.server.js +114 -111
  10. package/dist/files.server.mjs +114 -111
  11. package/dist/gallery.server.js +3 -3
  12. package/dist/gallery.server.mjs +3 -3
  13. package/dist/globals.server.js +1 -1
  14. package/dist/globals.server.mjs +1 -1
  15. package/dist/index-a8dffc0c.js +213 -0
  16. package/dist/index-d769324d.mjs +214 -0
  17. package/dist/mailing-37c2ba41.mjs +68 -0
  18. package/dist/mailing-fe16a26a.js +67 -0
  19. package/dist/main.css +1 -1
  20. package/dist/middlewares.server.js +1 -1
  21. package/dist/middlewares.server.mjs +1 -1
  22. package/dist/organizations.server.js +125 -25
  23. package/dist/organizations.server.mjs +125 -25
  24. package/dist/prometheus-framework.cjs.js +30 -29
  25. package/dist/prometheus-framework.es.js +2478 -2282
  26. package/dist/reports.server.js +1 -1
  27. package/dist/reports.server.mjs +1 -1
  28. package/dist/users.server.js +1 -1
  29. package/dist/users.server.mjs +1 -1
  30. package/package.json +4 -2
  31. package/src/assets/images/logo.svg +7 -7
  32. package/src/components/Block/Block.vue +77 -0
  33. package/src/components/Breadcrumbs/Breadcrumbs.vue +2 -2
  34. package/src/components/Button/Button.vue +32 -227
  35. package/src/components/Checkbox/Checkbox.vue +1 -1
  36. package/src/components/Chips/Chips.vue +8 -8
  37. package/src/components/DatePicker/DatePicker.vue +3 -4
  38. package/src/components/EditImages/EditImages.vue +32 -14
  39. package/src/{modules/globals/components/sections → components/Feed}/Feed.vue +60 -45
  40. package/src/components/FieldBig/FieldBig.vue +16 -5
  41. package/src/components/FieldPhone/FieldPhone.vue +2 -1
  42. package/src/components/Footer/Footer.vue +36 -27
  43. package/src/components/Header/Header.vue +161 -166
  44. package/src/components/Loader/Loader.vue +9 -2
  45. package/src/components/LocationMarker/LocationMarker.vue +38 -12
  46. package/src/components/LocationSelection/LocationSelection.vue +67 -75
  47. package/src/components/Magnifier/Magnifier.vue +3 -3
  48. package/src/components/Navigation/Navigation.vue +16 -16
  49. package/src/components/Popup/Popup.vue +8 -6
  50. package/src/components/Select/Select.vue +35 -6
  51. package/src/components/SelectMulti/SelectMulti.vue +5 -13
  52. package/src/components/Shader/Shader.vue +128 -0
  53. package/src/components/Sidebar/Sidebar.vue +71 -35
  54. package/src/components/Spoiler/Spoiler.vue +1 -1
  55. package/src/components/Tab/Tab.vue +1 -1
  56. package/src/components/Tooltip/Tooltip.vue +1 -1
  57. package/src/components/UploadImage/UploadImage.vue +4 -4
  58. package/src/components/UploadImageMultiple/UploadImageMultiple.vue +54 -10
  59. package/src/modules/applications/controllers/applications.controller.js +0 -1
  60. package/src/modules/auth/components/pages/EnterCode.vue +1 -1
  61. package/src/modules/auth/components/pages/EnterPassword.vue +3 -3
  62. package/src/modules/auth/components/pages/ResetPassword.vue +1 -2
  63. package/src/modules/auth/components/pages/SignIn.vue +26 -10
  64. package/src/modules/auth/components/pages/SignUp.vue +1 -2
  65. package/src/modules/auth/controllers/twofa.controller.js +4 -4
  66. package/src/modules/auth/localization/EnterCode.json +2 -2
  67. package/src/modules/auth/localization/EnterPassword.json +2 -2
  68. package/src/modules/auth/localization/ResetPassword.json +2 -2
  69. package/src/modules/auth/localization/SignIn.json +3 -3
  70. package/src/modules/auth/localization/SignUp.json +3 -3
  71. package/src/modules/auth/utils/server/verifyAppleIdToken.js +0 -1
  72. package/src/modules/backoffice/components/layouts/Backoffice.vue +1 -1
  73. package/src/modules/backoffice/components/pages/Dashboard.vue +171 -120
  74. package/src/modules/backoffice/router/backoffice.js +119 -129
  75. package/src/modules/chats/components/blocks/ChatMessage.vue +25 -0
  76. package/src/modules/chats/components/pages/ChatPage.vue +50 -0
  77. package/src/modules/chats/components/sections/ChatWindow.vue +38 -0
  78. package/src/modules/chats/controllers/chats.controller.js +32 -0
  79. package/src/modules/chats/models/chat.model.js +26 -0
  80. package/src/modules/chats/routes/chats.routes.js +53 -0
  81. package/src/modules/chats/store/chat.store.js +61 -0
  82. package/src/modules/community/components/blocks/CardBlogpost.vue +19 -4
  83. package/src/modules/community/components/layouts/Community.vue +96 -39
  84. package/src/modules/community/components/pages/Blog.vue +4 -3
  85. package/src/modules/community/components/pages/BlogPost.vue +10 -1
  86. package/src/modules/community/components/pages/CreateBlogPost.vue +36 -17
  87. package/src/modules/community/components/sections/HotPosts.vue +3 -3
  88. package/src/modules/community/components/sections/JoinUs.vue +19 -13
  89. package/src/modules/community/controllers/blog.controller.js +3 -4
  90. package/src/modules/community/controllers/utils/queryProcessor.js +16 -17
  91. package/src/modules/community/models/blogpost.model.js +6 -3
  92. package/src/modules/community/store/blogposts.js +1 -0
  93. package/src/modules/constructor/components/elements/Embed.vue +12 -1
  94. package/src/modules/constructor/components/elements/ImageUpload.vue +2 -2
  95. package/src/modules/constructor/components/elements/Textarea.vue +6 -1
  96. package/src/modules/constructor/components/elements/Video.vue +79 -0
  97. package/src/modules/constructor/components/elements/VideoPlayer.vue +59 -0
  98. package/src/modules/constructor/components/elements/Youtube.vue +52 -0
  99. package/src/modules/constructor/components/sections/Constructor.vue +27 -3
  100. package/src/modules/events/components/layouts/layoutEvents.vue +7 -28
  101. package/src/modules/files/controllers/files.controller.js +9 -22
  102. package/src/modules/files/middlewares/server/index.js +2 -2
  103. package/src/modules/files/middlewares/server/middlewareBusboy.js +137 -0
  104. package/src/modules/files/routes/files.routes.js +9 -9
  105. package/src/modules/globals/localization/vue-i18n.js +8 -1
  106. package/src/modules/globals/mixins/mixins.js +23 -13
  107. package/src/modules/globals/router/routerGuards.js +2 -2
  108. package/src/modules/globals/store/globals.js +86 -9
  109. package/src/modules/globals/utils/mailing.js +24 -3
  110. package/src/modules/icons/entities/IconCommunity.vue +4 -4
  111. package/src/modules/icons/entities/IconEvents.vue +1 -1
  112. package/src/modules/icons/entities/IconGroups.vue +1 -1
  113. package/src/modules/icons/entities/IconPrice.vue +5 -0
  114. package/src/modules/icons/entities/IconProfile.vue +5 -0
  115. package/src/modules/icons/entities/IconShopcart.vue +5 -0
  116. package/src/modules/icons/entities/IconTime.vue +5 -0
  117. package/src/modules/icons/icons.client.js +4 -0
  118. package/src/modules/icons/labels/LabelAppStore.vue +24 -24
  119. package/src/modules/icons/labels/LabelGooglePlay.vue +9 -9
  120. package/src/modules/icons/logos/Logotype.vue +20 -0
  121. package/src/modules/icons/navigation/IconAdd.vue +17 -0
  122. package/src/modules/icons/navigation/IconChevronBottom.vue +18 -0
  123. package/src/modules/icons/navigation/IconChevronRight.vue +3 -3
  124. package/src/modules/icons/navigation/IconDelete.vue +19 -0
  125. package/src/modules/icons/navigation/IconMinus.vue +15 -0
  126. package/src/modules/icons/navigation/IconSearch.vue +17 -0
  127. package/src/modules/icons/navigation/IconUpload.vue +16 -0
  128. package/src/modules/icons/placeholders/PlaceholderImage.vue +5 -0
  129. package/src/modules/icons/placeholders/PlaceholderOrganizationPic.vue +20 -0
  130. package/src/modules/icons/placeholders/PlaceholderUserpic.vue +4 -18
  131. package/src/modules/icons/socials/instagram.vue +1 -1
  132. package/src/modules/icons/socials/line.vue +1 -1
  133. package/src/modules/icons/socials/reddit.vue +1 -1
  134. package/src/modules/icons/socials/telegram.vue +1 -1
  135. package/src/modules/icons/socials/twitter.vue +1 -1
  136. package/src/modules/icons/socials/youtube.vue +1 -1
  137. package/src/modules/landing/components/sections/Guide.vue +92 -0
  138. package/src/modules/landing/components/sections/MobileApp.vue +23 -12
  139. package/src/modules/marketplace/components/layouts/Marketplace.vue +76 -188
  140. package/src/modules/marketplace/components/pages/Catalog.vue +65 -119
  141. package/src/modules/marketplace/components/sections/Filters.vue +195 -0
  142. package/src/modules/marketplace/store/marketplace.js +2 -2
  143. package/src/modules/middlewares/client/auth.validation.js +0 -6
  144. package/src/modules/middlewares/client/states.validation.js +2 -8
  145. package/src/modules/middlewares/server/authJwt.js +1 -1
  146. package/src/modules/mobile/components/Menu/MenuItem.vue +3 -6
  147. package/src/modules/openai/controllers/openai.controller.js +0 -1
  148. package/src/modules/orders/components/blocks/CardOrder.vue +166 -0
  149. package/src/modules/orders/components/blocks/CardOrderItem.vue +59 -66
  150. package/src/modules/orders/components/blocks/Positions.vue +4 -4
  151. package/src/modules/orders/components/pages/EditOrder.vue +78 -142
  152. package/src/modules/orders/components/pages/FormOrder.vue +192 -0
  153. package/src/modules/orders/components/pages/Order.vue +326 -120
  154. package/src/modules/orders/components/pages/Orders.vue +13 -9
  155. package/src/modules/orders/components/pages/{ViewOrder.vue → Orders_refact.vue} +13 -10
  156. package/src/modules/orders/components/partials/ShopCart.vue +22 -13
  157. package/src/modules/orders/components/sections/EmptyState.vue +1 -1
  158. package/src/modules/orders/components/sections/{Form.vue → FormOrderDetails.vue} +38 -106
  159. package/src/modules/orders/controllers/orders.controller.js +37 -28
  160. package/src/modules/orders/models/order.model.js +39 -9
  161. package/src/modules/orders/router/orders.router.js +23 -2
  162. package/src/modules/orders/routes/orders.routes.js +14 -17
  163. package/src/modules/orders/store/orders.js +24 -9
  164. package/src/modules/orders/store/shopcart.js +20 -19
  165. package/src/modules/organizations/components/blocks/CardDepartment.vue +1 -1
  166. package/src/modules/organizations/components/blocks/CardOrganization.vue +98 -46
  167. package/src/modules/organizations/components/blocks/Rating.vue +1 -1
  168. package/src/modules/organizations/components/blocks/Socials.vue +11 -3
  169. package/src/modules/organizations/components/elements/ButtonToggleMembership.vue +1 -1
  170. package/src/modules/organizations/components/pages/Department.vue +1 -1
  171. package/src/modules/organizations/components/pages/DepartmentEdit.vue +4 -4
  172. package/src/modules/organizations/components/pages/Members.vue +6 -4
  173. package/src/modules/organizations/components/pages/Organization.vue +120 -49
  174. package/src/modules/organizations/components/pages/OrganizationEdit.vue +8 -1
  175. package/src/modules/organizations/components/pages/Organizations.vue +27 -6
  176. package/src/modules/organizations/components/sections/DetailsTab.vue +11 -9
  177. package/src/modules/organizations/components/sections/Feed.vue +0 -3
  178. package/src/modules/organizations/components/sections/FeedDepartments.vue +2 -2
  179. package/src/modules/organizations/controllers/organizations.controller.js +126 -15
  180. package/src/modules/organizations/controllers/utils/addMembersQuantity.js +19 -9
  181. package/src/modules/organizations/models/organization.model.js +5 -2
  182. package/src/modules/organizations/router/members.router.js +1 -3
  183. package/src/modules/organizations/router/organizations.js +8 -6
  184. package/src/modules/organizations/router/products.router.js +36 -2
  185. package/src/modules/organizations/store/organizations.js +38 -84
  186. package/src/modules/pages/controllers/pages.controller.js +0 -4
  187. package/src/modules/payments/controller/payments.controller.js +1 -1
  188. package/src/modules/products/components/blocks/CardLeftover.vue +17 -22
  189. package/src/modules/products/components/blocks/CardPosition.vue +96 -49
  190. package/src/modules/products/components/blocks/CardProduct.vue +24 -53
  191. package/src/modules/products/components/blocks/Images360.vue +4 -4
  192. package/src/modules/products/components/blocks/ImagesThumbnails.vue +2 -7
  193. package/src/modules/products/components/blocks/ListPositions.vue +74 -0
  194. package/src/modules/products/components/elements/Price.vue +11 -5
  195. package/src/modules/products/components/elements/THC.vue +6 -6
  196. package/src/modules/products/components/pages/{LeftoverAdd.vue → EditLeftover.vue} +93 -79
  197. package/src/modules/products/components/pages/Leftovers.vue +74 -70
  198. package/src/modules/products/components/pages/Product.vue +4 -7
  199. package/src/modules/products/components/pages/ProductEdit.vue +230 -88
  200. package/src/modules/products/components/pages/ProductRecommmendation.vue +1 -1
  201. package/src/modules/products/components/pages/Products.vue +6 -3
  202. package/src/modules/products/components/pages/ProductsBackoffice.vue +3 -5
  203. package/src/modules/products/components/sections/EditModifications.vue +3 -3
  204. package/src/modules/products/components/sections/EditProductInfo.vue +40 -50
  205. package/src/modules/products/components/sections/FilterProducts.vue +57 -18
  206. package/src/modules/products/components/sections/HeroRecommendation.vue +233 -99
  207. package/src/modules/products/components/sections/MenuSection.vue +127 -0
  208. package/src/modules/products/components/sections/PopularProducts.vue +81 -37
  209. package/src/modules/products/components/sections/SectionProduct.vue +21 -23
  210. package/src/modules/products/controllers/leftovers.controller.js +11 -1
  211. package/src/modules/products/controllers/products.controller.js +100 -97
  212. package/src/modules/products/models/leftover.model.js +6 -4
  213. package/src/modules/products/models/product.model.js +13 -1
  214. package/src/modules/products/routes/products.routes.js +4 -4
  215. package/src/modules/products/store/leftovers.js +4 -24
  216. package/src/modules/products/store/products.js +44 -30
  217. package/src/modules/spots/components/blocks/CardSpot.vue +43 -72
  218. package/src/modules/spots/components/layouts/Spots.vue +9 -91
  219. package/src/modules/spots/components/pages/Map.vue +171 -62
  220. package/src/modules/spots/components/pages/Spot.vue +1 -1
  221. package/src/modules/spots/components/pages/SpotEdit.vue +131 -174
  222. package/src/modules/spots/controllers/spots.controller.js +1 -0
  223. package/src/modules/spots/models/spot.model.js +6 -3
  224. package/src/modules/spots/store/spots.js +42 -48
  225. package/src/modules/users/components/pages/Profile.vue +6 -28
  226. package/src/modules/users/components/pages/ProfileBlogposts.vue +1 -1
  227. package/src/modules/users/components/pages/ProfileEdit.vue +1 -1
  228. package/src/modules/users/components/pages/ProfileEvents.vue +1 -1
  229. package/src/modules/users/components/pages/ProfileOrganizations.vue +1 -1
  230. package/src/modules/users/router/users.js +1 -1
  231. package/src/modules/wallet/components/pages/Wallet.vue +105 -109
  232. package/src/modules/wallet/controllers/crypto.controller.js +129 -0
  233. package/src/modules/wallet/models/reward.model.js +53 -0
  234. package/src/modules/wallet/routes/crypto.routes.js +36 -0
  235. package/src/modules/wallet/store/wallet.js +52 -49
  236. package/src/styles/base/all.scss +143 -11
  237. package/src/styles/base/backgrounds.scss +2 -34
  238. package/src/styles/base/borders.scss +18 -23
  239. package/src/styles/base/scrolling.scss +97 -29
  240. package/src/styles/base/{shadows.scss → shadow_transitions_hover_refactor.scss} +55 -2
  241. package/src/styles/config.scss +69 -17
  242. package/src/styles/layout.scss +12 -182
  243. package/src/styles/reset.scss +20 -21
  244. package/src/styles/responsive.scss +4 -67
  245. package/src/styles/theme.scss +3 -4
  246. package/src/styles/typography.scss +15 -17
  247. package/src/assets/fonts/AvenirNext-Bold.woff2 +0 -0
  248. package/src/assets/fonts/AvenirNext-DemiBold.woff2 +0 -0
  249. package/src/assets/fonts/AvenirNext-Heavy.woff2 +0 -0
  250. package/src/assets/fonts/AvenirNext-Medium.woff2 +0 -0
  251. package/src/assets/fonts/AvenirNext-Regular.woff2 +0 -0
  252. package/src/assets/fonts/AvenirNext-UltraLight.woff2 +0 -0
  253. package/src/modules/files/middlewares/server/md.js +0 -152
  254. package/src/modules/files/middlewares/server/middlewareMulter.js +0 -121
  255. package/src/modules/organizations/controllers/organizations.new.controller.js +0 -372
  256. package/src/modules/products/components/blocks/EditCategories.vue +0 -68
  257. package/src/modules/products/components/sections/EditParameters.vue +0 -58
  258. package/src/modules/products/components/sections/EditProductImages.vue +0 -67
  259. package/src/modules/spots/components/sections/Feed.vue +0 -64
  260. package/src/styles/base/border-radius.scss +0 -47
  261. package/src/styles/base/cursors.scss +0 -23
  262. package/src/styles/base/height.scss +0 -60
  263. package/src/styles/base/hovers.scss +0 -110
  264. package/src/styles/base/positions.scss +0 -192
  265. package/src/styles/base/transitions.scss +0 -137
  266. package/src/styles/base/width.scss +0 -2
  267. package/src/styles/components/block.scss +0 -18
  268. package/src/styles/components/breadcrumbs.scss +0 -0
  269. package/src/styles/components/input.scss +0 -319
@@ -1,121 +0,0 @@
1
- // middlewareFactory.js
2
- const sharp = require('sharp');
3
- const fs = require('fs');
4
- const path = require('path');
5
- const multer = require('multer');
6
-
7
- const createStorage = (folderName, publicPath) => {
8
- console.log(folderName)
9
- console.log(publicPath)
10
-
11
- return multer.diskStorage({
12
- destination: function (req, file, cb) {
13
- let user = {};
14
- // try {
15
- // user = JSON.parse(req.cookies.user);
16
- // } catch (err) {
17
- // return cb(new Error('Unable to parse user from cookies'));
18
- // }
19
-
20
- // if (!user._id) {
21
- // return cb(new Error('No user _id found in cookies'));
22
- // }
23
-
24
- const userUploadPath = path.join(publicPath, folderName);
25
-
26
- fs.mkdirSync(userUploadPath, { recursive: true });
27
-
28
- cb(null, userUploadPath);
29
- },
30
- filename: function (req, file, cb) {
31
- cb(null, Date.now() + path.extname(file.originalname));
32
- }
33
- });
34
- }
35
-
36
- const createThumbnail = async (originalPath, thumbnailPath) => {
37
- try {
38
- await sharp(originalPath)
39
- .rotate()
40
- .resize({ width: 800 })
41
- .toFile(thumbnailPath);
42
- } catch (error) {
43
- console.error("Error creating thumbnail:", error);
44
- }
45
- };
46
-
47
- const middlewareFactory = (db, publicPath) => {
48
- const uploadSingleFileMiddleware = async (req, res, next) => {
49
-
50
- const folderName = req.query.folderName ? req.query.folderName : 'unsorted'; // получаем folderName из параметров запроса
51
- const upload = multer({ storage: createStorage(folderName, publicPath) }).single('file');
52
- console.log(folderName)
53
- console.log(publicPath)
54
-
55
- upload(req, res, function(err) {
56
- if (err instanceof multer.MulterError) {
57
- // A Multer error occurred when uploading.
58
- return res.status(500).json(err);
59
- } else if (err) {
60
- // An unknown error occurred when uploading.
61
- return res.status(500).json(err);
62
- }
63
- next(); // Everything went fine.
64
- });
65
- }
66
-
67
- const uploadMultipleFilesMiddleware = async (req, res, next) => {
68
-
69
-
70
- const folderName = req.query.folderName ? req.query.folderName : 'unsorted'; // получаем folderName из параметров запроса
71
- const upload = multer({ storage: createStorage(folderName, publicPath) }).array('file');
72
-
73
- upload(req, res, function(err) {
74
- if (err instanceof multer.MulterError) {
75
- return res.status(500).json(err);
76
- } else if (err) {
77
- return res.status(500).json(err);
78
- }
79
- next();
80
- });
81
- }
82
-
83
- const generatePreviewMiddleware = async (req, res, next) => {
84
- if (req.file) { // if a single file is uploaded
85
- try {
86
- const originalPath = req.file.path;
87
- const thumbnailPath = path.join(
88
- path.dirname(originalPath),
89
- 'thumbnail_' + path.basename(originalPath)
90
- );
91
- await createThumbnail(originalPath, thumbnailPath);
92
- } catch (error) {
93
- console.error('Error generating preview for single file:', error);
94
- }
95
- } else if (req.files) { // if multiple files are uploaded
96
- try {
97
- await Promise.all(req.files.map(async file => {
98
- const originalPath = file.path;
99
- const thumbnailPath = path.join(
100
- path.dirname(originalPath),
101
- 'thumbnail_' + path.basename(originalPath)
102
- );
103
- await createThumbnail(originalPath, thumbnailPath);
104
- }));
105
- } catch (error) {
106
- console.error('Error generating previews for multiple files:', error);
107
- }
108
- }
109
- next();
110
- };
111
-
112
-
113
-
114
- return {
115
- uploadSingleFileMiddleware,
116
- uploadMultipleFilesMiddleware,
117
- generatePreviewMiddleware
118
- };
119
- };
120
-
121
- module.exports = middlewareFactory;
@@ -1,372 +0,0 @@
1
- const jwt = require("jsonwebtoken");
2
- const axios = require('axios');
3
- const bcrypt = require("bcryptjs");
4
- const { uuid } = require('uuidv4');
5
- const ObjectId = require('mongoose').Types.ObjectId;
6
- const { Client } = require('@googlemaps/google-maps-services-js');
7
- const client = new Client({});
8
-
9
- const addUserStatusFields = require('@pf/src/modules/organizations/controllers/utils/addUserStatusFields');
10
- const addMembersQuantity = require('@pf/src/modules/organizations/controllers/utils/addMembersQuantity');
11
-
12
- const parseCookie = require('@pf/src/modules/globals/utils/parseCookie'); // Assuming this is your utility function for parsing cookies
13
-
14
- const controllerFactory = (db) => {
15
- const Organization = db.organization;
16
- const Membership = db.membership;
17
- const User = db.user;
18
- const Role = db.role;
19
-
20
- const read = async (req, res) => {
21
- const sortStage = getSortStage(req.query.sortParam || 'numberOfProducts', req.query.sortOrder || 'desc');
22
-
23
- const priceConditions = getPriceConditions(req.query.prices?.split(',') || []);
24
- const matchConditions = getMatchConditions(req.query);
25
- const locationStage = await getLocationMatchStage(req.query.location, req.query.address, req.query.city, req.query.state, req.query.country);
26
- const lookupStages = getLookupStages();
27
-
28
- // Стадии агрегации
29
- const stages = [
30
- ...lookupStages,
31
- ...matchConditions,
32
- ...locationStage,
33
- ];
34
-
35
-
36
- let stages = [];
37
-
38
- stages = [
39
- ...queryProcessorGlobals.getBasicOptions(
40
- req.query
41
- ),
42
- // Sorting and Pagination
43
- ...queryProcessorGlobals.getSortingOptions(
44
- req.query.sortParam,
45
- req.query.sortOrder,
46
- ),
47
- ...queryProcessorGlobals.getPaginationOptions(
48
- req.query.skip,
49
- req.query.limit
50
- ),
51
- // For creator
52
- queryProcessorGlobals.getCreatorUserLookupStage(),
53
- queryProcessorGlobals.getCreatorOrganizationLookupStage(),
54
- // For owner
55
- queryProcessorGlobals.getOwnerUserLookupStage(),
56
- queryProcessorGlobals.getOwnerOrganizationLookupStage(),
57
- queryProcessorGlobals.getAddFieldsCreatorOwnerStage(),
58
- ]
59
-
60
- const categories = req.query.categories?.split(',') || [];
61
- const delivery = req.query.delivery?.split(',') || [];
62
- const prices = req.query.prices?.split(',') || [];
63
-
64
- let priceConditions = prices.map(priceRange => {
65
- if (priceRange.startsWith('<')) return { "products.price": { $lt: parseInt(priceRange.slice(1)) } };
66
- if (priceRange.startsWith('>')) return { "products.price": { $gt: parseInt(priceRange.slice(1)) } };
67
- const [min, max] = priceRange.split('-').map(Number);
68
- return { "products.price": { $gte: min, $lte: max } };
69
- });
70
-
71
- console.log(req.query.postable)
72
-
73
- const matchConditions = [
74
- ...(req.query._id ? [{ _id: new ObjectId(req.query._id) }] : []),
75
- ...(req.query.owner ? [{ owner: new ObjectId(req.query.owner) }] : []),
76
- ...(req.query.member ? [{"memberships.user": new ObjectId(req.query.member), "memberships.role": { $ne: 'subscriber' } } ] : [] ),
77
- ...(req.query.subscriber ? [{"memberships.user": new ObjectId(req.query.subscriber), "memberships.role": 'subscriber'} ] : [] ),
78
- ...(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' } } ] } ] } ] : [] ),
79
- ...(req.query.types ? [{ types: { $in: req.query.types } }] : []), // Если req.query.types - строка
80
- // to remove
81
- ...(req.query.onlyuser ? [{ "memberships.user": new ObjectId(req.query.onlyuser) }] : []),
82
- ...(categories.length > 0 ? [{ "products.category": { $in: categories } }] : []),
83
- ...(delivery.length > 0 ? [{ "departments.delivery": { $all: delivery } }] : []),
84
- ...(priceConditions.length > 0 ? [{ $or: priceConditions }] : []),
85
- ];
86
-
87
-
88
- let { location, address, city, state, country } = req.query;
89
-
90
- if (!location && address || city || state || country) {
91
- let geoLocation;
92
-
93
- // Create a string to pass to geocoding client
94
- const searchString = [address, city, state, country].filter(Boolean).join(', ');
95
-
96
- try {
97
- const geoResponse = await client.geocode({
98
- params: {
99
- address: searchString,
100
- key: 'AIzaSyDDR6WgYB7XMt7yTDDzQNEdF_gTdUiq8dI',
101
- },
102
- });
103
-
104
- if (geoResponse.data.results && geoResponse.data.results.length > 0) {
105
- geoLocation = geoResponse.data.results[0].geometry.location;
106
- } else {
107
- return res.status(400).send({ message: 'Unable to geocode the provided location.' });
108
- }
109
- } catch (err) {
110
- console.log(err)
111
- return res.status(500).send({ message: 'Error occurred while geocoding.' });
112
- }
113
-
114
- // Determine the search radius based on the level of specificity
115
- const radius = city ? 50 : state ? 100 : 500;
116
-
117
- // Use MongoDB's $geoNear to find organizations within a certain radius
118
- matchConditions.push({
119
- "departments.location.coordinates": {
120
- $geoWithin: {
121
- $centerSphere: [
122
- [geoLocation.lng, geoLocation.lat],
123
- radius / 6378.1
124
- ]
125
- }
126
- }
127
- });
128
- }
129
-
130
- if (location) {
131
- console.log('Location is ' + location)
132
-
133
- if (typeof location === 'string') {
134
- location = JSON.parse(location);
135
- }
136
-
137
- let [lng, lat] = location.coordinates;
138
-
139
- matchConditions.push({
140
- "departments.location.coordinates": {
141
- $geoWithin: {
142
- $centerSphere: [
143
- [lng, lat],
144
- 20 / 6378.1
145
- ]
146
- }
147
- }
148
- });
149
- }
150
-
151
- const matchStage = matchConditions.length > 0 ? { $match: { $and: matchConditions } } : null;
152
-
153
- const stages = [
154
- {
155
- $lookup: {
156
- from: "products",
157
- localField: "_id",
158
- foreignField: "organization",
159
- as: "products"
160
- }
161
- },
162
- {
163
- $addFields: {
164
- numberOfProducts: { $size: '$products' }
165
- }
166
- },
167
- {
168
- $lookup: {
169
- from: "departments",
170
- localField: "_id",
171
- foreignField: "organization",
172
- as: "departments"
173
- }
174
- },
175
- {
176
- $lookup: {
177
- from: "spots",
178
- localField: "_id",
179
- foreignField: "organization",
180
- as: "spots"
181
- }
182
- },
183
- {
184
- $lookup: {
185
- from: "memberships",
186
- localField: "_id",
187
- foreignField: "target",
188
- as: "memberships"
189
- }
190
- },
191
- addMembersQuantity(),
192
- addUserStatusFields(req.query.user),
193
- {
194
- $addFields: {
195
- numberOfProducts: { $size: '$products' }
196
- }
197
- },
198
- ...(matchStage != null ? [matchStage] : []),
199
- { $sort: sort },
200
- { $skip: options.skip },
201
- { $limit: options.limit }
202
- ];
203
-
204
- try {
205
- console.log(stages)
206
- const organizations = await Organization.aggregate(stages);
207
- console.log(organizations)
208
- res.status(200).send(organizations);
209
- } catch(err) {
210
- console.log(err)
211
- return res.status(500).send({ message: err });
212
- }
213
- };
214
-
215
- const fetch = async (req, res) => {
216
- const Organization = db.organization;
217
-
218
- let query = {};
219
-
220
- console.log(req.query)
221
-
222
- // Fetch by website
223
- if (req.query._id) {
224
- query['_id'] = req.query._id;
225
- }
226
-
227
- if (req.query.owner) {
228
- query['owner'] = req.query.owner;
229
- }
230
-
231
- // Fetch by type
232
- if (req.query.type) {
233
- query.types = req.query.type;
234
- }
235
-
236
- // Pagination options
237
- let options = {};
238
- options.skip = parseInt(req.query.skip) || 0;
239
- options.limit = parseInt(req.query.limit) || 10;
240
-
241
- try {
242
- const organizations = await Organization.find(query, null, options);
243
-
244
- if (!organizations || organizations.length === 0) {
245
- return res.status(404).send({ message: "Organizations not found." });
246
- }
247
-
248
- // Send fetched organizations
249
- res.status(200).send(organizations);
250
- } catch(err) {
251
- return res.status(500).send({ message: err });
252
- }
253
- };
254
-
255
- const create = async (req, res) => {
256
- if(req.body._id === null) {
257
- delete req.body._id;
258
- }
259
-
260
- try {
261
- const organization = new Organization(req.body);
262
- const savedOrganization = await organization.save();
263
-
264
- const membership = new Membership({
265
- user: savedOrganization.owner,
266
- type: 'organization',
267
- target: savedOrganization._id,
268
- role: 'owner',
269
- });
270
-
271
- const savedMembership = await membership.save();
272
-
273
- res.status(201).json(savedOrganization);
274
- } catch (error) {
275
- console.error('Error:', error);
276
- res.status(500).send(error);
277
- }
278
- };
279
-
280
-
281
-
282
- const update = async (req, res) => {
283
- try {
284
- const organizationId = req.params._id;
285
-
286
- const updatedData = req.body;
287
-
288
- const organization = await Organization.findByIdAndUpdate(organizationId, updatedData, {
289
- new: true,
290
- runValidators: true,
291
- });
292
-
293
- if (!organization) {
294
- return res.status(404).json({ message: 'Organization not found' });
295
- }
296
-
297
- res.status(200).json({ message: 'Organization updated successfully', organization });
298
- } catch (error) {
299
- res.status(500).json({ error: error.message });
300
- }
301
- };
302
-
303
- const deleteOrganization = async (req, res) => {
304
- Organization.findOneAndRemove({ _id: req.params._id })
305
- .then(organization => {
306
- if (!organization) {
307
- return res.status(404).send({ message: "Organization not found" });
308
- }
309
-
310
- // Удаление всех memberships, связанных с этой организацией
311
- Membership.deleteMany({ organization: req.params._id })
312
- .then(() => {
313
- const newToken = jwt.sign({
314
- _id: user._id,
315
- organization: null
316
- }, process.env.SECRET_KEY, {
317
- expiresIn: 86400 // 24 hours
318
- });
319
-
320
- res.send({ newToken });
321
- })
322
- .catch(err => {
323
- res.status(500).send({ message: "Error deleting memberships: " + err.message });
324
- });
325
- })
326
- .catch(err => {
327
- res.status(500).send({ message: err.message });
328
- });
329
- };
330
-
331
- return {
332
- fetch,
333
- read,
334
- create,
335
- update,
336
- delete: deleteOrganization // Map the method to 'delete' key
337
- };
338
- };
339
-
340
- async function getGeoLocation(req, res) {
341
- let { location, address, city, state, country } = req.query;
342
-
343
- if (!location && (address || city || state || country)) {
344
- let geoLocation;
345
-
346
- try {
347
- const geoResponse = await client.geocode({
348
- params: {
349
- address: `${state}, ${country}`,
350
- key: 'AIzaSyDDR6WgYB7XMt7yTDDzQNEdF_gTdUiq8dI',
351
- },
352
- });
353
-
354
- if (geoResponse.data.results && geoResponse.data.results.length > 0) {
355
- return geoResponse.data.results[0].geometry.location;
356
- } else {
357
- return res.status(400).send({ message: 'Unable to geocode the provided location.' });
358
- }
359
- } catch (err) {
360
- console.log(err)
361
- return res.status(500).send({ message: 'Error occurred while geocoding.' });
362
- }
363
- } else if (location) {
364
- if (typeof location === 'string') {
365
- location = JSON.parse(location);
366
- }
367
-
368
- return { lat: location.coordinates[1], lng: location.coordinates[0] };
369
- }
370
- }
371
-
372
- module.exports = controllerFactory;
@@ -1,68 +0,0 @@
1
- <template>
2
- <div class="mn-b-big">
3
-
4
- <!-- Title -->
5
- <div class="mn-b-small flex-nojustify flex-v-center flex">
6
- <h5 class="mn-r-thin">{{title}}</h5>
7
- <button @click="addArrayObject(obj,prop)" class="i-small pd-thin button-delete button">+</button>
8
- </div>
9
- <p v-if="category[name].length == 0" class="mn-b-big">У продукта еще не заданы {{title}}</p>
10
- <!-- Categories -->
11
- <div v-if="category[name].length != 0" class="flex-wrap flex-column flex block">
12
- <div class="mn-b-small w-100 flex-nowrap flex" v-for="(item, index) in category[name]">
13
- <InputText
14
- :obj="obj"
15
- :prop="prop + '[' + index + '].' + keyname"
16
- :value="Object.keys(item).length === 0 ? '' : item[keyname]"
17
- placeholder="Введите название параметра"
18
- class="mn-r-small"/>
19
- <InputText
20
- :obj="obj"
21
- :prop="prop + '[' + index + '].' + parname"
22
- :value="Object.keys(item).length === 0 ? '' : item[parname]"
23
- placeholder="Введите значение"
24
- class="mn-r-small"/>
25
-
26
- <a @click="deleteArrayObject(obj, prop + '[' + index + ']')" class="mn-l-small button">
27
- Удалить
28
- </a>
29
- </div>
30
- </div>
31
-
32
- </div>
33
- </template>
34
-
35
- <script setup="props">
36
- /////////////////////////////
37
- // COMPONENT DEPENDENCIES
38
- /////////////////////////////
39
- import { toRefs } from 'vue';
40
- // Import components
41
-
42
- /////////////////////////////
43
- // HELPERS
44
- /////////////////////////////
45
-
46
- /////////////////////////////
47
- // CREATED
48
- /////////////////////////////
49
- const props = defineProps({
50
- category: Object,
51
- obj: String,
52
- prop: String,
53
- title: String,
54
- name: String,
55
- keyname: String,
56
- parname: String,
57
- });
58
-
59
- const { category } = toRefs(props);
60
-
61
- /////////////////////////////
62
- // MOUNTED
63
- /////////////////////////////
64
- </script>
65
-
66
- <style lang="scss">
67
-
68
- </style>
@@ -1,58 +0,0 @@
1
- <template>
2
- <div class="mn-b-big">
3
- <div class="mn-b-small flex-nowrap flex">
4
- <h5 class="mn-r-thin">{{ title }}</h5>
5
- <button @click="addArrayObject" class="i-small pd-thin button-delete button">+</button>
6
- </div>
7
-
8
- <div class="flex-column flex">
9
- <p v-if="items.length == 0" class="w-100 mn-b-small">{{ emptyMessage }}</p>
10
- <Button v-if="items.length == 0" @click="addArrayObject" class="button">{{ addButtonLabel }}</Button>
11
- <div class="mn-b-medium w-100 flex-nowrap flex" v-for="(item, index) in items" :key="index">
12
- <Field
13
- v-model:field="item[keyName]"
14
- placeholder="Название параметра"
15
- class="w-100 mn-r-small bg-white radius-small pd-medium"
16
- />
17
- <Field
18
- v-model:field="item[valueName]"
19
- placeholder="Значение параметра"
20
- class="w-100 bg-white radius-small pd-medium"
21
- />
22
- <button @click="deleteArrayObject(index)" class="mn-l-small button">
23
- <svg class="i-small" fill="none" height="20" viewBox="0 0 20 20" width="20" xmlns="http://www.w3.org/2000/svg"><path clip-rule="evenodd" d="m7.27124 0h5.45456c1.0041 0 1.8182.814027 1.8182 1.81818v.90899h2.7278c1.0042 0 1.8182.81402 1.8182 1.81818v1.81818c0 1.00415-.814 1.81818-1.8182 1.81818h-.0735l-.8363 10.00009c0 1.0042-.814 1.8182-1.8182 1.8182h-9.09087c-1.00416 0-1.81818-.814-1.81504-1.7427l-.83964-10.07559h-.07187c-1.00415 0-1.818177-.81403-1.818177-1.81818v-1.81818c0-1.00416.814027-1.81818 1.818177-1.81818h2.72668v-.90899c0-1.004153.81402-1.81818 1.81818-1.81818zm-1.81889 18.1819-.83047-10h10.75152l-.827 9.9245-.0031.0755zm-2.72612-11.81799v-1.81818h14.54547v1.81818zm10.00137-4.54571v.90909h-5.45456v-.90909z" fill="#8a8a8a" fill-rule="evenodd"/></svg>
24
- </button>
25
- </div>
26
- </div>
27
- </div>
28
- </template>
29
-
30
- <script setup="props">
31
- import { toRefs } from 'vue';
32
- import Button from "@pf/src/components/Button/Button.vue";
33
- import Field from "@pf/src/components/Field/Field.vue";
34
-
35
- const emit = defineEmits(['add-info','delete-info'])
36
-
37
- function addArrayObject() {
38
- emit('add-info', {});
39
- }
40
-
41
- function deleteArrayObject(index) {
42
- emit('delete-info', index);
43
- }
44
-
45
- const props = defineProps({
46
- items: {
47
- type: Array,
48
- default: () => [],
49
- },
50
- title: String,
51
- addButtonLabel: String,
52
- emptyMessage: String,
53
- keyName: String,
54
- valueName: String,
55
- });
56
-
57
- const { items, title, emptyMessage, addButtonLabel, keyName, valueName } = toRefs(props);
58
- </script>
@@ -1,67 +0,0 @@
1
- <template>
2
- <div>
3
- <p v-if="product.images.length < 1" class="mn-b-big">
4
- The product doesn't have any images yet.
5
- </p>
6
-
7
- <VueDraggableNext class="cols-4 dragArea list-group w-full" :list="product.images" :sort="true" @change="log">
8
- <div v-for="(image, index) in product.images" class="flex-column block">
9
- <img class="w-100 mn-b-small" :src="(FILE_SERVER_URL || '') + image" />
10
- <a @click="deleteImage(index)" class="w-100 br-grey br-solid br-1px button">Удалить</a>
11
- </div>
12
- </VueDraggableNext>
13
-
14
- <UploadImageMultiple
15
- @update:images="onImagesUpdate"
16
- :uploadPath="'organizations/' + $route.params._id + '/products'"
17
- class="mn-t-semi pd-small w-100 button bg-main"
18
- />
19
- </div>
20
- </template>
21
-
22
- <script setup="props">
23
- /////////////////////////////
24
- // COMPONENT DEPENDENCIES
25
- /////////////////////////////
26
- import { toRefs } from 'vue';
27
- import { VueDraggableNext } from 'vue-draggable-next'
28
- // Import components
29
-
30
- import UploadImageMultiple from "@pf/src/components/UploadImageMultiple/UploadImageMultiple.vue";
31
- /////////////////////////////
32
- // HELPERS
33
- /////////////////////////////
34
-
35
- /////////////////////////////
36
- // CREATED
37
- /////////////////////////////
38
- import * as products from '@pf/src/modules/products/store/products';
39
-
40
- const props = defineProps({
41
- product: Object,
42
- });
43
-
44
-
45
- function onImagesUpdate(newImages) {
46
- console.log(newImages)
47
- console.log(products.state.current.images)
48
- products.state.current.images.push(...newImages);
49
- }
50
-
51
- function deleteImage(index) {
52
- products.state.current.images.splice(index, 1);
53
- }
54
-
55
-
56
- function afterSubmit() {
57
- location.reload();
58
- }
59
-
60
- /////////////////////////////
61
- // MOUNTED
62
- /////////////////////////////
63
- </script>
64
-
65
- <style lang="scss">
66
-
67
- </style>