@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.
- 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.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/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 +143 -11
- 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,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>
|