@ozdao/martyrs 0.2.562 → 0.2.563

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (182) hide show
  1. package/dist/{abac-DC2x92Pa.js → abac-DYoheWuc.js} +2 -1
  2. package/dist/{core.logger-VRHh-WUW.js → core.cache-DALYFDdy.js} +10 -59
  3. package/dist/core.logger-C3q8A9dl.js +51 -0
  4. package/dist/core.server.js +1 -1
  5. package/dist/{crud-DFFgLl09.js → crud-C7FSTUes.js} +2 -1
  6. package/dist/inventory.server.js +4 -3
  7. package/dist/{main-TV4u6Jux.js → main-CmjWiDVF.js} +402 -402
  8. package/dist/marketplace.server.js +389 -0
  9. package/dist/martyrs/src/components/Button/{Button.vue.js → Button.vue2.js} +3 -3
  10. package/dist/martyrs/src/components/Button/Button.vue2.js.map +1 -0
  11. package/dist/martyrs/src/components/EditImages/{EditImages.vue2.js → EditImages.vue.js} +2 -2
  12. package/dist/martyrs/src/components/EditImages/EditImages.vue.js.map +1 -0
  13. package/dist/martyrs/src/components/Feed/Carousel.vue.js +1 -1
  14. package/dist/martyrs/src/components/Feed/Feed.vue.js +2 -2
  15. package/dist/martyrs/src/components/Field/{Field.vue2.js → Field.vue.js} +2 -2
  16. package/dist/martyrs/src/components/Field/Field.vue.js.map +1 -0
  17. package/dist/martyrs/src/components/FieldBig/FieldBig.vue.js +2 -2
  18. package/dist/martyrs/src/components/Loader/{Loader.vue2.js → Loader.vue.js} +2 -2
  19. package/dist/martyrs/src/components/Loader/Loader.vue.js.map +1 -0
  20. package/dist/martyrs/src/components/LocationMarker/LocationMarker.vue.js +1 -1
  21. package/dist/martyrs/src/components/Media/Media.vue.js +1 -1
  22. package/dist/martyrs/src/components/Select/{Select.vue2.js → Select.vue.js} +2 -2
  23. package/dist/martyrs/src/components/Select/Select.vue.js.map +1 -0
  24. package/dist/martyrs/src/components/SelectMulti/{SelectMulti.vue.js → SelectMulti.vue2.js} +2 -2
  25. package/dist/martyrs/src/components/SelectMulti/SelectMulti.vue2.js.map +1 -0
  26. package/dist/martyrs/src/components/Tab/{Tab.vue2.js → Tab.vue.js} +2 -2
  27. package/dist/martyrs/src/components/Tab/Tab.vue.js.map +1 -0
  28. package/dist/martyrs/src/components/UploadImage/UploadImage.vue.js +1 -1
  29. package/dist/martyrs/src/components/UploadImageMultiple/UploadImageMultiple.vue.js +1 -1
  30. package/dist/martyrs/src/modules/auth/views/components/pages/EnterCode.vue.js +1 -1
  31. package/dist/martyrs/src/modules/auth/views/components/pages/EnterPassword.vue.js +3 -3
  32. package/dist/martyrs/src/modules/auth/views/components/pages/Invite.vue.js +3 -3
  33. package/dist/martyrs/src/modules/auth/views/components/pages/Profile.vue.js +2 -2
  34. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileBlogposts.vue.js +1 -1
  35. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEdit.vue.js +1 -1
  36. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditAccount.vue.js +1 -1
  37. package/dist/martyrs/src/modules/auth/views/components/pages/ProfileEditProfile.vue.js +2 -2
  38. package/dist/martyrs/src/modules/auth/views/components/pages/ResetPassword.vue.js +3 -3
  39. package/dist/martyrs/src/modules/auth/views/components/pages/SignIn.vue.js +3 -3
  40. package/dist/martyrs/src/modules/auth/views/components/pages/SignUp.vue.js +3 -3
  41. package/dist/martyrs/src/modules/auth/views/components/sections/ProfileEditCredentials.vue.js +2 -2
  42. package/dist/martyrs/src/modules/backoffice/components/partials/Sidebar.vue.js +1 -1
  43. package/dist/martyrs/src/modules/community/components/layouts/Community.vue.js +1 -1
  44. package/dist/martyrs/src/modules/community/components/pages/BlogPost.vue.js +2 -2
  45. package/dist/martyrs/src/modules/community/components/pages/CreateBlogPost.vue.js +2 -2
  46. package/dist/martyrs/src/modules/constructor/components/elements/Card.vue.js +1 -1
  47. package/dist/martyrs/src/modules/constructor/components/elements/Embed.vue.js +1 -1
  48. package/dist/martyrs/src/modules/core/views/components/blocks/BlockSearch.vue.js +1 -1
  49. package/dist/martyrs/src/modules/core/views/components/blocks/CardHeader.vue.js +1 -1
  50. package/dist/martyrs/src/modules/core/views/components/blocks/PopupAuth.vue.js +1 -1
  51. package/dist/martyrs/src/modules/core/views/components/blocks/PopupDateSelector.vue.js +2 -2
  52. package/dist/martyrs/src/modules/core/views/components/layouts/Client.vue.js +2 -2
  53. package/dist/martyrs/src/modules/core/views/components/partials/Header.vue.js +2 -2
  54. package/dist/martyrs/src/modules/core/views/components/partials/NavigationBar.vue.js +1 -1
  55. package/dist/martyrs/src/modules/core/views/components/sections/{Filters.vue2.js → Filters.vue.js} +2 -2
  56. package/dist/martyrs/src/modules/core/views/components/sections/Filters.vue.js.map +1 -0
  57. package/dist/martyrs/src/modules/core/views/components/sections/SectionPageTitle.vue.js +1 -1
  58. package/dist/martyrs/src/modules/core/views/components/sections/filters/FilterRange.vue.js +1 -1
  59. package/dist/martyrs/src/modules/core/views/components/sections/filters/FiltersGroup.vue.js +1 -3
  60. package/dist/martyrs/src/modules/core/views/components/sections/filters/FiltersGroup.vue.js.map +1 -1
  61. package/dist/martyrs/src/modules/events/components/elements/ButtonCheck.vue.js +1 -1
  62. package/dist/martyrs/src/modules/events/components/elements/ButtonJoin.vue.js +1 -1
  63. package/dist/martyrs/src/modules/events/components/pages/EditEvent.vue.js +5 -5
  64. package/dist/martyrs/src/modules/events/components/pages/EditEventTickets.vue.js +2 -2
  65. package/dist/martyrs/src/modules/events/components/pages/Event.vue.js +3 -3
  66. package/dist/martyrs/src/modules/events/components/pages/EventsBackoffice.vue.js +1 -1
  67. package/dist/martyrs/src/modules/events/components/sections/EditTickets.vue.js +2 -2
  68. package/dist/martyrs/src/modules/events/components/sections/Feed.vue.js +1 -1
  69. package/dist/martyrs/src/modules/events/components/sections/List.vue.js +1 -1
  70. package/dist/martyrs/src/modules/gallery/components/sections/BackofficeGallery.vue.js +5 -5
  71. package/dist/martyrs/src/modules/inventory/components/forms/AdjustmentForm.vue.js +3 -3
  72. package/dist/martyrs/src/modules/inventory/components/forms/ColumnSettingsMenu.vue.js +1 -1
  73. package/dist/martyrs/src/modules/inventory/components/forms/HistoryView.vue.js +1 -1
  74. package/dist/martyrs/src/modules/inventory/components/forms/StockAlertsForm.vue.js +3 -3
  75. package/dist/martyrs/src/modules/inventory/components/pages/InventoryEdit.vue.js +3 -3
  76. package/dist/martyrs/src/modules/landing/components/sections/SectionFeatures.vue.js +1 -1
  77. package/dist/martyrs/src/modules/landing/components/sections/SectionFeatures.vue.js.map +1 -1
  78. package/dist/martyrs/src/modules/marketplace/marketplace.client.js +5 -9
  79. package/dist/martyrs/src/modules/marketplace/marketplace.client.js.map +1 -1
  80. package/dist/martyrs/src/modules/marketplace/views/components/{layouts → pages}/Marketplace.vue.js +16 -20
  81. package/dist/martyrs/src/modules/marketplace/views/components/pages/Marketplace.vue.js.map +1 -0
  82. package/dist/martyrs/src/modules/marketplace/views/components/sections/SectionMenu.vue.js +1 -1
  83. package/dist/martyrs/src/modules/marketplace/views/router/marketplace.router.js +39 -0
  84. package/dist/martyrs/src/modules/marketplace/views/router/marketplace.router.js.map +1 -0
  85. package/dist/martyrs/src/modules/music/components/cards/AlbumCard.vue.js +1 -1
  86. package/dist/martyrs/src/modules/music/components/cards/ArtistCardSmall.vue.js +1 -1
  87. package/dist/martyrs/src/modules/music/components/cards/PlaylistCard.vue.js +1 -1
  88. package/dist/martyrs/src/modules/music/components/cards/TrackListCard.vue.js +1 -1
  89. package/dist/martyrs/src/modules/music/components/forms/AlbumForm.vue.js +3 -3
  90. package/dist/martyrs/src/modules/music/components/forms/ArtistForm.vue.js +4 -4
  91. package/dist/martyrs/src/modules/music/components/forms/PlaylistForm.vue.js +2 -2
  92. package/dist/martyrs/src/modules/music/components/forms/SearchForm.vue.js +1 -1
  93. package/dist/martyrs/src/modules/music/components/forms/TrackForm.vue.js +3 -3
  94. package/dist/martyrs/src/modules/music/components/pages/Album.vue.js +2 -2
  95. package/dist/martyrs/src/modules/music/components/pages/Artist.vue.js +2 -2
  96. package/dist/martyrs/src/modules/music/components/pages/MusicLibrary.vue.js +1 -1
  97. package/dist/martyrs/src/modules/music/components/pages/Playlist.vue.js +2 -2
  98. package/dist/martyrs/src/modules/music/components/pages/SearchResults.vue.js +2 -2
  99. package/dist/martyrs/src/modules/music/components/pages/Track.vue.js +2 -2
  100. package/dist/martyrs/src/modules/music/components/pages/TrackCreate.vue.js +1 -1
  101. package/dist/martyrs/src/modules/music/components/player/MusicPlayer.vue.js +1 -1
  102. package/dist/martyrs/src/modules/notifications/components/pages/Notifications.vue.js +1 -1
  103. package/dist/martyrs/src/modules/orders/components/forms/FormApplicationDetails.vue.js +3 -3
  104. package/dist/martyrs/src/modules/orders/components/forms/FormCustomerDetails.vue.js +3 -3
  105. package/dist/martyrs/src/modules/orders/components/forms/FormSelectCustomer.vue.js +2 -2
  106. package/dist/martyrs/src/modules/orders/components/pages/OrderBackoffice.vue.js +2 -2
  107. package/dist/martyrs/src/modules/orders/components/pages/OrderCreate.vue.js +1 -1
  108. package/dist/martyrs/src/modules/orders/components/pages/OrderCreateBackoffice.vue.js +3 -3
  109. package/dist/martyrs/src/modules/orders/components/pages/Orders.vue.js +1 -1
  110. package/dist/martyrs/src/modules/orders/components/sections/ApplicationDetails.vue.js +1 -1
  111. package/dist/martyrs/src/modules/orders/components/sections/CustomerDetails.vue.js +1 -1
  112. package/dist/martyrs/src/modules/orders/components/sections/FormDelivery.vue.js +3 -3
  113. package/dist/martyrs/src/modules/orders/components/sections/FormPayment.vue.js +1 -1
  114. package/dist/martyrs/src/modules/organizations/components/elements/ButtonToggleMembership.vue.js +1 -1
  115. package/dist/martyrs/src/modules/organizations/components/forms/AddExistingMembersForm.vue.js +1 -1
  116. package/dist/martyrs/src/modules/organizations/components/forms/DepartmentForm.vue.js +2 -2
  117. package/dist/martyrs/src/modules/organizations/components/forms/InviteForm.vue.js +2 -2
  118. package/dist/martyrs/src/modules/organizations/components/pages/OrganizationBackoffice.vue.js +1 -1
  119. package/dist/martyrs/src/modules/organizations/components/pages/OrganizationEdit.vue.js +5 -5
  120. package/dist/martyrs/src/modules/organizations/components/pages/Organizations.vue.js +1 -1
  121. package/dist/martyrs/src/modules/organizations/components/sections/Documents.vue.js +3 -3
  122. package/dist/martyrs/src/modules/organizations/components/sections/MembersAdd.vue.js +3 -3
  123. package/dist/martyrs/src/modules/organizations/components/sections/Organizations.vue.js +4 -4
  124. package/dist/martyrs/src/modules/pages/views/components/blocks/CardPage.vue.js +2 -2
  125. package/dist/martyrs/src/modules/pages/views/components/pages/PageEdit.vue.js +2 -2
  126. package/dist/martyrs/src/modules/pages/views/components/partials/SidebarPages.vue.js +1 -1
  127. package/dist/martyrs/src/modules/products/components/elements/Image360.vue.js +1 -1
  128. package/dist/martyrs/src/modules/products/components/pages/Categories.vue.js +1 -1
  129. package/dist/martyrs/src/modules/products/components/pages/CategoryEdit.vue.js +5 -5
  130. package/dist/martyrs/src/modules/products/components/pages/Product.vue.js +2 -2
  131. package/dist/martyrs/src/modules/products/components/pages/ProductEdit.vue.js +6 -6
  132. package/dist/martyrs/src/modules/products/components/pages/ProductRecommmendation.vue.js +1 -1
  133. package/dist/martyrs/src/modules/products/components/pages/Products.vue.js +3 -3
  134. package/dist/martyrs/src/modules/products/components/sections/EditAttributes.vue.js +2 -2
  135. package/dist/martyrs/src/modules/products/components/sections/EditDiscounts.vue.js +3 -3
  136. package/dist/martyrs/src/modules/products/components/sections/EditVariants.vue.js +4 -4
  137. package/dist/martyrs/src/modules/products/components/sections/ProductConfigurator.vue.js +1 -1
  138. package/dist/martyrs/src/modules/products/components/sections/ProductsRecommended.vue.js +1 -1
  139. package/dist/martyrs/src/modules/products/components/sections/SectionProduct.vue.js +2 -2
  140. package/dist/martyrs/src/modules/rents/views/components/pages/Gant/GanttToolbar.vue.js +2 -2
  141. package/dist/martyrs/src/modules/rents/views/components/pages/Rents.vue.js +1 -1
  142. package/dist/martyrs/src/modules/rents/views/components/pages/RentsEdit.vue.js +1 -1
  143. package/dist/martyrs/src/modules/reports/components/sections/FormReport.vue.js +2 -2
  144. package/dist/martyrs/src/modules/spots/components/blocks/SpotMemberModify.vue.js +2 -2
  145. package/dist/martyrs/src/modules/spots/components/layouts/Spots.vue.js +1 -1
  146. package/dist/martyrs/src/modules/spots/components/pages/Map.vue.js +1 -1
  147. package/dist/martyrs/src/modules/spots/components/pages/SpotEdit.vue.js +4 -4
  148. package/dist/martyrs/src/modules/spots/components/sections/WorktimeEdit.vue.js +3 -3
  149. package/dist/martyrs/src/modules/wallet/views/components/blocks/CardDeposit.vue.js +1 -1
  150. package/dist/martyrs/src/modules/wallet/views/components/blocks/CryptoDeposit.vue.js +2 -2
  151. package/dist/martyrs/src/modules/wallet/views/components/pages/Wallet.vue.js +2 -2
  152. package/dist/martyrs.es.js +1 -1
  153. package/dist/music.server.js +4 -3
  154. package/dist/node_modules/.pnpm/qrcode@1.5.4/node_modules/qrcode/lib/core/utils.js +1 -1
  155. package/dist/node_modules/.pnpm/qrcode@1.5.4/node_modules/qrcode/lib/renderer/utils.js +1 -1
  156. package/dist/orders.server.js +2 -2
  157. package/dist/organizations.server.js +9 -219
  158. package/dist/products.server.js +4 -3
  159. package/dist/queryProcessorOrganizations-BB11WFpc.js +221 -0
  160. package/dist/rents.server.js +2 -1
  161. package/dist/{web-Cq5tyhkl.js → web-cNKIl_cL.js} +1 -1
  162. package/package.json +1 -1
  163. package/src/modules/core/views/components/sections/filters/FiltersGroup.vue +3 -4
  164. package/src/modules/landing/components/sections/SectionFeatures.vue +1 -1
  165. package/src/modules/marketplace/marketplace.client.js +3 -10
  166. package/src/modules/marketplace/views/components/{layouts → pages}/Marketplace.vue +7 -16
  167. package/src/modules/marketplace/views/router/marketplace.router.js +37 -45
  168. package/dist/martyrs/src/components/Button/Button.vue.js.map +0 -1
  169. package/dist/martyrs/src/components/EditImages/EditImages.vue2.js.map +0 -1
  170. package/dist/martyrs/src/components/Field/Field.vue2.js.map +0 -1
  171. package/dist/martyrs/src/components/Loader/Loader.vue2.js.map +0 -1
  172. package/dist/martyrs/src/components/Select/Select.vue2.js.map +0 -1
  173. package/dist/martyrs/src/components/SelectMulti/SelectMulti.vue.js.map +0 -1
  174. package/dist/martyrs/src/components/Tab/Tab.vue2.js.map +0 -1
  175. package/dist/martyrs/src/modules/core/views/components/sections/Filters.vue2.js.map +0 -1
  176. package/dist/martyrs/src/modules/marketplace/marketplace.router.js +0 -63
  177. package/dist/martyrs/src/modules/marketplace/marketplace.router.js.map +0 -1
  178. package/dist/martyrs/src/modules/marketplace/views/components/layouts/Marketplace.vue.js.map +0 -1
  179. package/dist/martyrs/src/modules/marketplace/views/components/pages/Catalog.vue.js +0 -73
  180. package/dist/martyrs/src/modules/marketplace/views/components/pages/Catalog.vue.js.map +0 -1
  181. package/src/modules/marketplace/marketplace.router.js +0 -66
  182. package/src/modules/marketplace/views/components/pages/Catalog.vue +0 -74
@@ -0,0 +1,389 @@
1
+ import { m as middlewareIndexFactory } from "./index-_Edcmck_.js";
2
+ import { C as CacheNamespaced } from "./core.cache-DALYFDdy.js";
3
+ import { q as queryProcessorCore } from "./queryProcessor-CBQgZycY.js";
4
+ import { b as getLookupStages } from "./queryProcessorOrganizations-BB11WFpc.js";
5
+ import { Types } from "mongoose";
6
+ import * as googleMapsServicesJs from "@googlemaps/google-maps-services-js";
7
+ const lookupConfigs = {
8
+ availability: {
9
+ lookup: {
10
+ from: "stockavailabilities",
11
+ localField: "_id",
12
+ foreignField: "storage",
13
+ pipeline: [
14
+ {
15
+ $match: {
16
+ $expr: { $gt: ["$available", 0] }
17
+ }
18
+ },
19
+ {
20
+ $project: {
21
+ _id: 1,
22
+ product: 1,
23
+ variant: 1,
24
+ available: 1,
25
+ quantity: 1
26
+ }
27
+ }
28
+ ],
29
+ as: "availability"
30
+ }
31
+ },
32
+ variants: {
33
+ lookup: {
34
+ from: "variants",
35
+ let: { variantIds: "$availability.variant" },
36
+ pipeline: [
37
+ {
38
+ $match: {
39
+ $expr: {
40
+ $in: ["$_id", "$$variantIds"]
41
+ },
42
+ status: "published"
43
+ }
44
+ },
45
+ {
46
+ $project: {
47
+ _id: 1,
48
+ product: 1,
49
+ name: 1,
50
+ price: 1,
51
+ unit: 1,
52
+ images: 1,
53
+ sku: 1
54
+ }
55
+ }
56
+ ],
57
+ as: "variants"
58
+ }
59
+ },
60
+ products: {
61
+ lookup: {
62
+ from: "products",
63
+ localField: "organization",
64
+ foreignField: "owner.target",
65
+ pipeline: [
66
+ {
67
+ $match: {
68
+ status: "published"
69
+ }
70
+ },
71
+ {
72
+ $lookup: {
73
+ from: "variants",
74
+ localField: "_id",
75
+ foreignField: "product",
76
+ pipeline: [
77
+ {
78
+ $project: {
79
+ _id: 1,
80
+ name: 1,
81
+ price: 1,
82
+ unit: 1,
83
+ images: 1,
84
+ sku: 1
85
+ }
86
+ }
87
+ ],
88
+ as: "variants"
89
+ }
90
+ },
91
+ {
92
+ $project: {
93
+ _id: 1,
94
+ name: 1,
95
+ description: 1,
96
+ images: 1,
97
+ category: 1,
98
+ "owner.target": 1,
99
+ "owner.type": 1,
100
+ variants: 1
101
+ }
102
+ }
103
+ ],
104
+ as: "products"
105
+ }
106
+ },
107
+ organizations: {
108
+ lookup: {
109
+ from: "organizations",
110
+ let: { orgIds: "$products.owner.target" },
111
+ pipeline: [
112
+ {
113
+ $match: {
114
+ $expr: {
115
+ $in: ["$_id", "$$orgIds"]
116
+ }
117
+ }
118
+ },
119
+ {
120
+ $project: {
121
+ _id: 1,
122
+ "profile.name": 1,
123
+ "profile.photo": 1,
124
+ "profile.description": 1,
125
+ "profile.tags": 1,
126
+ rating: 1,
127
+ official: 1
128
+ }
129
+ }
130
+ ],
131
+ as: "organizations"
132
+ }
133
+ }
134
+ };
135
+ const ObjectId = Types.ObjectId;
136
+ const { Client } = googleMapsServicesJs;
137
+ const client = new Client({});
138
+ const getBasicMatchConditions = (query) => {
139
+ const conditions = [];
140
+ if (query.delivery) {
141
+ let deliveryMethods = Array.isArray(query.delivery) ? query.delivery : typeof query.delivery === "string" ? query.delivery.split(",") : [];
142
+ deliveryMethods = deliveryMethods.filter(Boolean).map((m) => m.trim());
143
+ if (deliveryMethods.length > 0) {
144
+ conditions.push({ delivery: { $in: deliveryMethods } });
145
+ }
146
+ }
147
+ if (query.payment) {
148
+ let paymentMethods = Array.isArray(query.payment) ? query.payment : typeof query.payment === "string" ? query.payment.split(",") : [];
149
+ paymentMethods = paymentMethods.filter(Boolean).map((m) => m.trim());
150
+ if (paymentMethods.length > 0) {
151
+ conditions.push({ payment: { $in: paymentMethods } });
152
+ }
153
+ }
154
+ return conditions;
155
+ };
156
+ const getPriceConditions = (priceMin, priceMax) => {
157
+ if (!priceMin && !priceMax) return [];
158
+ const conditions = {};
159
+ if (priceMin !== void 0 && priceMin !== null && priceMin !== "") {
160
+ conditions["products.variants.price"] = { $gte: parseFloat(priceMin) };
161
+ }
162
+ if (priceMax !== void 0 && priceMax !== null && priceMax !== "") {
163
+ if (conditions["products.variants.price"]) {
164
+ conditions["products.variants.price"].$lte = parseFloat(priceMax);
165
+ } else {
166
+ conditions["products.variants.price"] = { $lte: parseFloat(priceMax) };
167
+ }
168
+ }
169
+ return Object.keys(conditions).length > 0 ? [{ $match: conditions }] : [];
170
+ };
171
+ const getCategoryConditions = (categories) => {
172
+ if (!categories || categories.length === 0) return [];
173
+ const categoriesArray = Array.isArray(categories) ? categories : categories.split(",");
174
+ return [
175
+ {
176
+ $match: {
177
+ "products.category": { $in: categoriesArray.map((id) => new ObjectId(id)) }
178
+ }
179
+ }
180
+ ];
181
+ };
182
+ const getContainConditions = (contain) => {
183
+ if (!contain) return [];
184
+ const conditions = contain.map((property) => ({
185
+ [property]: { $exists: true, $not: { $size: 0 } }
186
+ }));
187
+ return conditions.length > 0 ? [{ $match: { $and: conditions } }] : [];
188
+ };
189
+ const hasLocationParams = (query) => query.location || query.address || query.city || query.state || query.country;
190
+ const resolveLocation = async (query) => {
191
+ if (query.location) {
192
+ const parsedLocation = typeof query.location === "string" ? JSON.parse(query.location) : query.location;
193
+ const coordinates = parsedLocation.lng ? [parsedLocation.lng, parsedLocation.lat] : parsedLocation.coordinates;
194
+ return { coordinates: coordinates.map((coord) => parseFloat(coord)) };
195
+ }
196
+ const searchString = [query.address, query.city, query.state, query.country].filter(Boolean).join(", ");
197
+ try {
198
+ const geoResponse = await client.geocode({
199
+ params: {
200
+ address: searchString,
201
+ key: process.env.GOOGLE_MAPS_API_KEY
202
+ }
203
+ });
204
+ if (!geoResponse.data.results?.length) {
205
+ throw new Error("Unable to geocode the provided location.");
206
+ }
207
+ const { lng, lat } = geoResponse.data.results[0].geometry.location;
208
+ return { coordinates: [lng, lat] };
209
+ } catch (err) {
210
+ throw new Error("Error occurred while geocoding.");
211
+ }
212
+ };
213
+ const getRadius = (query) => {
214
+ if (query.locationRadius) return parseFloat(query.locationRadius) / 6378.1;
215
+ if (query.city) return 25 / 6378.1;
216
+ if (query.state) return 50 / 6378.1;
217
+ return null;
218
+ };
219
+ const getDistanceStages = (location) => [
220
+ {
221
+ $addFields: {
222
+ distance: {
223
+ $function: {
224
+ body: `function(spotCoords, userCoords, isMiles) {
225
+ function toRad(x) {
226
+ return x * Math.PI / 180;
227
+ }
228
+ var lon1 = spotCoords[0];
229
+ var lat1 = spotCoords[1];
230
+ var lon2 = userCoords[0];
231
+ var lat2 = userCoords[1];
232
+ var R = 6371;
233
+ if (isMiles) R = 3959;
234
+ var x1 = lat2 - lat1;
235
+ var dLat = toRad(x1);
236
+ var x2 = lon2 - lon1;
237
+ var dLon = toRad(x2);
238
+ var a = Math.sin(dLat / 2) * Math.sin(dLat / 2) +
239
+ Math.cos(toRad(lat1)) * Math.cos(toRad(lat2)) *
240
+ Math.sin(dLon / 2) * Math.sin(dLon / 2);
241
+ var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
242
+ var d = R * c;
243
+ return d;
244
+ }`,
245
+ args: ["$location.coordinates", location.coordinates, false],
246
+ lang: "js"
247
+ }
248
+ }
249
+ }
250
+ }
251
+ ];
252
+ const getSpotsLocationStages = async (query) => {
253
+ if (!hasLocationParams(query)) {
254
+ return { stages: [], userLocation: null };
255
+ }
256
+ const location = await resolveLocation(query);
257
+ const radius = getRadius(query);
258
+ const geoStages = radius ? [
259
+ {
260
+ $match: {
261
+ "location.coordinates": {
262
+ $geoWithin: {
263
+ $centerSphere: [[location.coordinates[0], location.coordinates[1]], radius]
264
+ }
265
+ }
266
+ }
267
+ }
268
+ ] : [];
269
+ return {
270
+ stages: [...geoStages, ...getDistanceStages(location)],
271
+ userLocation: location
272
+ };
273
+ };
274
+ const controllerFactory = (db) => {
275
+ const Spot = db.spot;
276
+ const cache = new CacheNamespaced({ ttlSeconds: 60 * 5 });
277
+ const readCatalog = async (req, res) => {
278
+ console.log("marketplace catalog query", req.query);
279
+ try {
280
+ const cacheKey = JSON.stringify(req.query);
281
+ let cachedResult = await cache.get(cacheKey);
282
+ if (cachedResult) {
283
+ return res.status(200).send(cachedResult);
284
+ }
285
+ const matchConditions = getBasicMatchConditions(req.query);
286
+ const stages = [
287
+ // Базовые фильтры spots (delivery, payment)
288
+ ...matchConditions.length > 0 ? [{ $match: { $and: matchConditions } }] : [],
289
+ // Геопоиск ПЕРВЫМ (если есть location)
290
+ ...req.query.location || req.query.city || req.query.state || req.query.country ? (await getSpotsLocationStages(req.query)).stages : [{ $addFields: { distance: null } }],
291
+ // Lookups (без availability пока)
292
+ ...getLookupStages(["products", "organizations"], lookupConfigs),
293
+ // Фильтр по наличию products
294
+ ...getContainConditions(["products", "organizations"]),
295
+ // Фильтр по ценам
296
+ ...getPriceConditions(req.query.priceMin, req.query.priceMax),
297
+ // Фильтр по категориям
298
+ ...getCategoryConditions(req.query.categories),
299
+ // Group по organization
300
+ {
301
+ $group: {
302
+ _id: { $arrayElemAt: ["$organizations._id", 0] },
303
+ profile: { $first: { $arrayElemAt: ["$organizations.profile", 0] } },
304
+ rating: { $first: { $arrayElemAt: ["$organizations.rating", 0] } },
305
+ official: { $first: { $arrayElemAt: ["$organizations.official", 0] } },
306
+ views: { $first: { $arrayElemAt: ["$organizations.views", 0] } },
307
+ spots: {
308
+ $push: {
309
+ _id: "$_id",
310
+ name: "$profile.name",
311
+ address: "$address",
312
+ location: "$location",
313
+ distance: "$distance",
314
+ delivery: "$delivery",
315
+ payment: "$payment"
316
+ }
317
+ },
318
+ products: { $first: "$products" },
319
+ distance: { $min: "$distance" }
320
+ }
321
+ },
322
+ // Добавляем numberOfProducts
323
+ {
324
+ $addFields: {
325
+ numberOfProducts: { $size: { $ifNull: ["$products", []] } }
326
+ }
327
+ },
328
+ // Финальная структура
329
+ {
330
+ $project: {
331
+ _id: 1,
332
+ profile: 1,
333
+ rating: 1,
334
+ official: 1,
335
+ views: 1,
336
+ spots: 1,
337
+ products: 1,
338
+ distance: 1,
339
+ numberOfProducts: 1
340
+ }
341
+ },
342
+ // Сортировка
343
+ ...queryProcessorCore.getSortingOptions(req.query.sortParam || "distance", req.query.sortOrder),
344
+ // Пагинация
345
+ ...queryProcessorCore.getPaginationOptions(req.query.skip, req.query.limit)
346
+ ].filter(Boolean);
347
+ console.log("Marketplace pipeline:", JSON.stringify(stages, null, 2));
348
+ const catalog = await Spot.aggregate(stages);
349
+ await cache.setWithTags(cacheKey, catalog, ["marketplace_catalog"]);
350
+ res.status(200).send(catalog);
351
+ } catch (err) {
352
+ console.error("Marketplace catalog error:", err);
353
+ res.status(500).send({ message: err.message });
354
+ }
355
+ };
356
+ return {
357
+ readCatalog
358
+ };
359
+ };
360
+ const marketplaceRoutes = (function(app, db) {
361
+ const controller = controllerFactory(db);
362
+ const { authJwt } = middlewareIndexFactory(db);
363
+ app.get(
364
+ "/api/marketplace/catalog",
365
+ [
366
+ authJwt.verifyToken(true)
367
+ // Optional authentication
368
+ ],
369
+ controller.readCatalog
370
+ );
371
+ });
372
+ function initializeMarketplace(app, db, origins, publicPath) {
373
+ if (app) {
374
+ marketplaceRoutes(app, db);
375
+ }
376
+ }
377
+ const routes = {
378
+ marketplaceRoutes
379
+ };
380
+ const initialize = initializeMarketplace;
381
+ const marketplace_server = {
382
+ initialize: initializeMarketplace,
383
+ routes
384
+ };
385
+ export {
386
+ marketplace_server as default,
387
+ initialize,
388
+ routes
389
+ };
@@ -1,8 +1,8 @@
1
1
  import { ref, createElementBlock, openBlock, normalizeClass, withModifiers, createVNode, createCommentVNode, Transition, withCtx, createBlock, renderSlot, Fragment, createTextVNode, toDisplayString, createElementVNode } from "vue";
2
- import Loader from "../Loader/Loader.vue2.js";
2
+ import Loader from "../Loader/Loader.vue.js";
3
3
  import _sfc_main$1 from "../../modules/icons/navigation/IconCheckmark.vue.js";
4
4
  import _sfc_main$2 from "../../modules/icons/navigation/IconCross.vue.js";
5
- /* empty css */
5
+ /* empty css */
6
6
  const _hoisted_1 = ["disabled"];
7
7
  const _hoisted_2 = {
8
8
  key: 0,
@@ -155,4 +155,4 @@ const _sfc_main = {
155
155
  export {
156
156
  _sfc_main as default
157
157
  };
158
- //# sourceMappingURL=Button.vue.js.map
158
+ //# sourceMappingURL=Button.vue2.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Button.vue2.js","sources":["../../../../../src/components/Button/Button.vue"],"sourcesContent":["<script setup>\nimport { ref } from 'vue'\n\nimport Loader from '@martyrs/src/components/Loader/Loader.vue'\n\nimport IconCheckmark from '@martyrs/src/modules/icons/navigation/IconCheckmark.vue';\nimport IconCross from '@martyrs/src/modules/icons/navigation/IconCross.vue';\n\nconst props = defineProps({\n submit: {\n type: Function,\n default: async () => { console.log('Button click.') }\n },\n text: {\n type: Object,\n default: () => ({\n success: null,\n error: null\n })\n },\n counter: {\n type: Object\n },\n callback: {\n type: Function,\n default: async () => { console.log('Button callback.') }\n },\n callbackDelay: {\n type: Number,\n default: 750\n },\n showSucces: {\n type: Boolean,\n default: true\n },\n showLoader: {\n type: Boolean,\n default: true\n },\n validation: {\n type: Boolean,\n default: false\n },\n})\n\nconst emits = defineEmits(['error'])\n\nconst button = ref(null)\nconst error = ref(null)\nconst loading = ref(false)\nconst finished = ref(false)\n\nasync function Submit() {\n console.log('click')\n \n button.value.style['pointer-events'] = 'none'\n error.value = null\n loading.value = true\n\n // Функция для сброса состояния кнопки\n const resetButton = () => {\n if (button.value) {\n button.value.style.pointerEvents = 'auto'\n loading.value = false\n finished.value = false\n error.value = null\n }\n }\n\n try {\n await props.submit()\n\n button.value.classList.replace('bg-main', 'bg-second')\n loading.value = false\n\n // Используем функцию сброса состояния кнопки здесь\n if (props.showSucces) { \n finished.value = true\n setTimeout(() => {\n resetButton()\n button.value.classList.replace('bg-second', 'bg-main')\n }, 500)\n } else {\n resetButton()\n button.value.classList.replace('bg-second', 'bg-main')\n }\n\n // Если есть callback, мы также установим таймер для его вызова\n if (props.callback) setTimeout(() => props.callback(), props.callbackDelay)\n\n } catch (err) {\n emits('error', err)\n // Если возникла ошибка, мы изменяем стили и устанавливаем сообщение об ошибке\n button.value.classList.replace('bg-main', 'bg-fourth-nano')\n loading.value = false\n error.value = true\n \n // После задержки снова сбрасываем состояние кнопки\n setTimeout(() => {\n resetButton()\n // Так как класс кнопки был изменен, вернем его в исходное состояние\n button.value.classList.replace('bg-fourth-nano', 'bg-main')\n }, 1330)\n }\n}\n</script>\n\n<template>\n <button \n @click.stop=\"Submit\"\n :disabled=\"validation\"\n ref=\"button\"\n\t\tclass=\"button\"\n :class=\"{ 'button--disabled': loading || validation }\"\n >\n <Transition name=\"content\" mode=\"out-in\">\n <!-- Default slot content -->\n <span v-if=\"!loading && !error && !finished || !showLoader\" class=\"button-content\">\n <slot></slot>\n </span>\n <!-- Loading state -->\n <Loader v-else-if=\"loading && !error && showLoader\" class=\"icon button-content pos-relative pos-t-0 pos-l-0 loading\"/>\n <!-- Success state -->\n <span v-else-if=\"finished && showSucces\" class=\"button-content t-semi t-center w-100 loading t-black\">\n <template v-if=\"text.success\">\n {{ text.success }}\n </template>\n <IconCheckmark v-else class=\"icon\" />\n </span>\n <!-- Error state -->\n <span v-else-if=\"error\" class=\"button-content t-center w-100 error\">\n <template v-if=\"text.error\">\n {{ text.error }}\n </template>\n <IconCross v-else class=\"icon\" />\n </span>\n </Transition>\n \n <!-- Counter -->\n <div v-if=\"counter\" class=\"button-counter font-second flex flex-center\">\n <span>{{ counter }}</span>\n </div>\n </button>\n</template>\n\n<style lang=\"scss\">\nbutton[disabled] {\n opacity: 0.75 !important;\n pointer-events: none !important;\n cursor: default !important;\n color: rgba(var(--dark), 0.33) !important;\n background: rgba(var(--light), 1) !important;\n}\n\na.button {\n text-box: trim-both cap alphabetic;\n}\n\n.button {\n display: flex;\n padding: var(--small);\n border-radius: var(--small);\n text-box: trim-both cap alphabetic;\n transform: scale(1);\n opacity: 1;\n align-items: center;\n justify-content: center;\n color: black;\n text-align: center;\n font-size: 1rem;\n letter-spacing: 5%;\n transition: all 0.33s ease;\n\n &:hover {\n cursor: pointer;\n opacity: 0.9;\n }\n\n &:active {\n transform: scale(0.95);\n }\n\n &-small {\n padding: 0.75rem;\n border-radius: 0.5rem;\n height: fit-content;\n }\n\n .button-counter {\n position: absolute;\n right: -8px;\n bottom: -8px;\n background: yellow;\n height: 16px;\n border-radius: 16px;\n width: 16px;\n font-weight: 500;\n text-align: center;\n line-height: 16px;\n font-size: 10px;\n }\n}\n\n.button-content {\n display: flex;\n align-items: center;\n justify-content: center;\n gap: 8px;\n}\n\n.icon {\n width: 1rem;\n height: 1rem;\n}\n\n/* Vue Transitions */\n.content-enter-active,\n.content-leave-active {\n transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);\n}\n\n.content-enter-from {\n opacity: 0;\n transform: translateY(8px) scale(0.95);\n}\n\n.content-leave-to {\n opacity: 0;\n transform: translateY(-8px) scale(0.95);\n}\n\n.content-enter-to,\n.content-leave-from {\n opacity: 1;\n transform: translateY(0) scale(1);\n}\n</style>"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAQA,UAAM,QAAQ;AAqCd,UAAM,QAAQ;AAEd,UAAM,SAAS,IAAI,IAAI;AACvB,UAAM,QAAQ,IAAI,IAAI;AACtB,UAAM,UAAU,IAAI,KAAK;AACzB,UAAM,WAAW,IAAI,KAAK;AAE1B,mBAAe,SAAS;AACtB,cAAQ,IAAI,OAAO;AAEnB,aAAO,MAAM,MAAM,gBAAgB,IAAI;AACvC,YAAM,QAAQ;AACd,cAAQ,QAAQ;AAGhB,YAAM,cAAc,MAAM;AACxB,YAAI,OAAO,OAAO;AAChB,iBAAO,MAAM,MAAM,gBAAgB;AACnC,kBAAQ,QAAQ;AAChB,mBAAS,QAAQ;AACjB,gBAAM,QAAQ;AAAA,QAChB;AAAA,MACF;AAEA,UAAI;AACF,cAAM,MAAM,OAAM;AAElB,eAAO,MAAM,UAAU,QAAQ,WAAW,WAAW;AACrD,gBAAQ,QAAQ;AAGhB,YAAI,MAAM,YAAY;AACpB,mBAAS,QAAQ;AACjB,qBAAW,MAAM;AACf,wBAAW;AACX,mBAAO,MAAM,UAAU,QAAQ,aAAa,SAAS;AAAA,UACvD,GAAG,GAAG;AAAA,QACR,OAAO;AACL,sBAAW;AACX,iBAAO,MAAM,UAAU,QAAQ,aAAa,SAAS;AAAA,QACvD;AAGA,YAAI,MAAM,SAAU,YAAW,MAAM,MAAM,SAAQ,GAAI,MAAM,aAAa;AAAA,MAE5E,SAAS,KAAK;AACZ,cAAM,SAAS,GAAG;AAElB,eAAO,MAAM,UAAU,QAAQ,WAAW,gBAAgB;AAC1D,gBAAQ,QAAQ;AAChB,cAAM,QAAQ;AAGd,mBAAW,MAAM;AACf,sBAAW;AAEX,iBAAO,MAAM,UAAU,QAAQ,kBAAkB,SAAS;AAAA,QAC5D,GAAG,IAAI;AAAA,MACT;AAAA,IACF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -2,7 +2,7 @@ import { ref, watchEffect, createElementBlock, openBlock, createBlock, createCom
2
2
  import { VueDraggableNext } from "../../../../node_modules/.pnpm/vue-draggable-next@2.2.1_sortablejs@1.15.6_vue@3.5.13_typescript@5.8.3_/node_modules/vue-draggable-next/dist/vue-draggable-next.esm-bundler.js";
3
3
  import _sfc_main$2 from "../UploadImageMultiple/UploadImageMultiple.vue.js";
4
4
  import _sfc_main$1 from "../../modules/icons/navigation/IconCross.vue.js";
5
- /* empty css */
5
+ /* empty css */
6
6
  const _hoisted_1 = { class: "flex-nowrap flex gap-small" };
7
7
  const _hoisted_2 = { class: "pos-relative" };
8
8
  const _hoisted_3 = ["src"];
@@ -92,4 +92,4 @@ const _sfc_main = {
92
92
  export {
93
93
  _sfc_main as default
94
94
  };
95
- //# sourceMappingURL=EditImages.vue2.js.map
95
+ //# sourceMappingURL=EditImages.vue.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"EditImages.vue.js","sources":["../../../../../src/components/EditImages/EditImages.vue"],"sourcesContent":["<template>\n\t<div class=\"flex-nowrap flex gap-small\">\n <VueDraggableNext v-if=\"localImages.length > 0\" class=\"gap-small flex dragArea list-group w-full\" v-model=\"localImages\" @change=\"emitChanges\">\n\t\t\t<div v-for=\"(image, index) in localImages\" class=\"pos-relative\">\n\t\t\t\t<img loading=\"lazy\" class=\"i-extra object-fit-contain bg-black-transp-5 pd-nano radius-small o-hidden\" :src=\"(FILE_SERVER_URL || '') + image\" />\n\t\t\t\t\n <IconCross \n @click=\"deleteImage(index)\" \n class=\"cursor-pointer pos-absolute t-center flex-center flex radius-extra i-medium bg-red pos-t-10-negative pos-r-10-negative pd-micro\"\n />\n\t\t\t</div>\n\t\t</VueDraggableNext>\n <div\n v-if=\"localImages.length > 0\" \n class=\"i-extra uppercase flex-center flex radius-small o-hidden br-solid br-main br-2px pd-small\"\n >\n <UploadImageMultiple \n @update:images=\"onImagesUpdate\"\n text=\"Add\"\n :options=\"{\n showText: false\n }\"\n :uploadPath=\"'photos'\"\n class=\"radius-big\"\n />\n </div>\n\n\n\t\t<UploadImageMultiple \t\n v-if=\"localImages.length < 1\" \n @update:images=\"onImagesUpdate\"\n :uploadPath=\"props.uploadPath\"\n :text=\"props.text\"\n :options=\"props.options\"\n class=\"w-100 pd-medium\"\n />\n\t</div>\t\n</template>\n\n<script setup>\nimport { ref, defineProps, watchEffect } from 'vue';\nimport { VueDraggableNext } from 'vue-draggable-next'\nimport UploadImageMultiple from \"@martyrs/src/components/UploadImageMultiple/UploadImageMultiple.vue\";\nimport IconCross from '@martyrs/src/modules/icons/navigation/IconCross.vue';\n\nconst props = defineProps({\n images: Array,\n text: Object,\n options: Object,\n uploadPath: {\n type: Object,\n default: 'unsorted'\n }\n});\n\nconst emit = defineEmits(['update:images'])\n\nconst localImages = ref([...props.images])\n\nwatchEffect(() => {\n localImages.value = [...props.images]; // Обновление localImages при изменении props.images\n});\n\nconst emitChanges = () => {\n emit('update:images', localImages.value)\n}\n\nconst onImagesUpdate = (newImages) => {\n localImages.value = [...localImages.value, ...newImages]\n emitChanges()\n}\n\nconst deleteImage = (index) => {\n localImages.value.splice(index, 1)\n emitChanges()\n}\n</script>\n\n<style lang=\"scss\">\n// Your styles here\n</style>\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AA6CA,UAAM,QAAQ;AAUd,UAAM,OAAO;AAEb,UAAM,cAAc,IAAI,CAAC,GAAG,MAAM,MAAM,CAAC;AAEzC,gBAAY,MAAM;AAChB,kBAAY,QAAQ,CAAC,GAAG,MAAM,MAAM;AAAA,IACtC,CAAC;AAED,UAAM,cAAc,MAAM;AACxB,WAAK,iBAAiB,YAAY,KAAK;AAAA,IACzC;AAEA,UAAM,iBAAiB,CAAC,cAAc;AACpC,kBAAY,QAAQ,CAAC,GAAG,YAAY,OAAO,GAAG,SAAS;AACvD,kBAAW;AAAA,IACb;AAEA,UAAM,cAAc,CAAC,UAAU;AAC7B,kBAAY,MAAM,OAAO,OAAO,CAAC;AACjC,kBAAW;AAAA,IACb;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -1,7 +1,7 @@
1
1
  import { ref, onMounted, createElementBlock, openBlock, createBlock, createVNode, normalizeClass, unref, withCtx, Fragment, renderList, Transition, renderSlot } from "vue";
2
2
  import { useI18n } from "vue-i18n";
3
3
  import { useGlobalMixins } from "../../modules/core/views/mixins/mixins.js";
4
- import Loader from "../Loader/Loader.vue2.js";
4
+ import Loader from "../Loader/Loader.vue.js";
5
5
  import _sfc_main$2 from "../Slider/Slider.vue.js";
6
6
  import _sfc_main$1 from "../EmptyState/EmptyState.vue.js";
7
7
  /* empty css */
@@ -1,13 +1,13 @@
1
1
  import { mergeModels, useModel, ref, computed, watch, onMounted, onUnmounted, createElementBlock, openBlock, Fragment, createCommentVNode, createBlock, normalizeClass, withCtx, createVNode, renderList, resolveDynamicComponent, unref, TransitionGroup, renderSlot } from "vue";
2
2
  import { useGlobalMixins } from "../../modules/core/views/mixins/mixins.js";
3
- import Loader from "../Loader/Loader.vue2.js";
3
+ import Loader from "../Loader/Loader.vue.js";
4
4
  import Skeleton from "../Skeleton/Skeleton.vue2.js";
5
5
  import _sfc_main$6 from "../EmptyState/EmptyState.vue.js";
6
6
  import _sfc_main$2 from "../Dropdown/Dropdown.vue.js";
7
7
  import Calendar from "../Calendar/Calendar.vue2.js";
8
8
  import _sfc_main$1 from "../../modules/core/views/components/blocks/BlockSearch.vue.js";
9
9
  import _sfc_main$5 from "../../modules/core/views/components/blocks/BlockSorting.vue.js";
10
- import Filters from "../../modules/core/views/components/sections/Filters.vue2.js";
10
+ import Filters from "../../modules/core/views/components/sections/Filters.vue.js";
11
11
  import _sfc_main$4 from "../../modules/core/views/components/elements/ButtonSort.vue.js";
12
12
  import _sfc_main$3 from "../../modules/core/views/components/elements/ButtonDate.vue.js";
13
13
  /* empty css */
@@ -1,6 +1,6 @@
1
1
  import { ref, watch, nextTick, onMounted, createElementBlock, openBlock, Fragment, createElementVNode, createVNode, normalizeClass, renderSlot, createBlock, createCommentVNode, resolveDynamicComponent, toDisplayString, Transition, withCtx } from "vue";
2
2
  import _sfc_main$1 from "../../modules/icons/actions/IconShow.vue.js";
3
- /* empty css */
3
+ /* empty css */
4
4
  import _export_sfc from "../../../../_virtual/_plugin-vue_export-helper.js";
5
5
  const _hoisted_1 = {
6
6
  key: 2,
@@ -158,4 +158,4 @@ const Field = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-3699
158
158
  export {
159
159
  Field as default
160
160
  };
161
- //# sourceMappingURL=Field.vue2.js.map
161
+ //# sourceMappingURL=Field.vue.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Field.vue.js","sources":["../../../../../src/components/Field/Field.vue"],"sourcesContent":["<script setup>\nimport { ref, onMounted, nextTick, watch } from 'vue'\nimport IconShow from '@martyrs/src/modules/icons/actions/IconShow.vue';\nconst emit = defineEmits(['update:field', 'focus', 'blur']);\nconst props = defineProps({\n label: null,\n symbol: null,\n type: 'text',\n placeholder: 'Enter something here',\n field: null,\n value: null,\n validation: false,\n disabled: null,\n tabindex: -1,\n autofocus: false,\n icon: null, // Добавлен пропс для иконки\n name: null, // Имя поля для автозаполнения\n id: null // ID поля\n});\nif (props.value) {\n emit('update:field', props.value)\n}\nconst textarea = ref(null);\nconst input = ref(null);\nconst showPassword = ref(false);\n\nfunction resize() {\n if (!textarea.value) {\n return;\n }\n const el = textarea.value;\n el.style.height = '';\n const scrollHeight = el.scrollHeight;\n if (scrollHeight > 33) {\n el.style.height = scrollHeight + 'px';\n } else {\n el.style.height = '';\n }\n}\nfunction focus() {\n if (props.autofocus) {\n if (props.type === 'textarea' && textarea.value) {\n textarea.value.focus();\n } else if (input.value) {\n input.value.focus();\n }\n }\n}\nwatch(() => props.field, () => {\n if (props.type === 'textarea') {\n nextTick(resize);\n }\n});\nwatch(() => props.autofocus, (newVal) => {\n if (newVal) {\n nextTick(focus);\n }\n});\nonMounted(() => {\n nextTick(focus);\n nextTick(resize);\n});\nconst text = ref(props.field);\n</script>\n<template>\n <div\n :class=\"[\n $attrs.class,\n { 'bg-fourth-nano': validation }\n ]\"\n class=\"field-wrapper flex-center flex-nowrap flex\"\n >\n <!-- Слот для иконки -->\n <slot name=\"icon\" v-if=\"$slots.icon\" />\n <!-- Или компонент иконки через пропс -->\n <component :is=\"icon\" v-else-if=\"icon\" class=\"i-medium t-transp mn-r-thin\" />\n \n <div\n v-if=\"label\"\n class=\"t-transp mn-r-small\"\n >\n <span class=\"t-nowrap\">\n {{label}}\n </span>\n </div>\n <div class=\"w-100 pos-relative\">\n <input\n v-if=\"type !== 'textarea'\"\n ref=\"input\"\n @input=\"event => text = emit('update:field', event.target.value)\"\n @focus=\"event => emit('focus', event)\"\n @blur=\"event => emit('blur', event)\"\n :type=\"type === 'password' && !showPassword ? 'password' : type === 'password' ? 'text' : type\"\n class=\"w-100\"\n :value=\"field\"\n :placeholder=\"placeholder\"\n :tabindex=\"tabindex\"\n :disabled=\"disabled\"\n :autofocus=\"autofocus\"\n :name=\"name\"\n :id=\"id\"\n />\n <textarea\n v-else\n ref=\"textarea\"\n @input=\"event => text = emit('update:field', event.target.value)\"\n @focus=\"event => emit('focus', event)\"\n @blur=\"event => emit('blur', event)\"\n class=\"w-100\"\n :value=\"field\"\n :placeholder=\"placeholder\"\n :tabindex=\"tabindex\"\n :disabled=\"disabled\"\n :name=\"name\"\n :id=\"id\"\n />\n </div>\n <IconShow\n v-if=\"type === 'password'\"\n :show=\"!showPassword\"\n @click=\"showPassword = !showPassword\"\n class=\"i-medium cursor-pointer\"\n />\n <slot></slot>\n <div\n v-if=\"symbol\"\n class=\"t-transp mn-l-small\"\n >\n <span>\n {{symbol}}\n </span>\n </div>\n </div>\n <!-- Validation -->\n <transition name=\"fade\">\n <div v-if=\"validation\" class=\"mn-t-thin mn-b-thin mn-b-thin invalid-feedback\">\n * {{validation.message}}\n </div>\n </transition>\n</template>\n<style scoped>\ninput,\ntextarea,\nspan {\n color: inherit;\n line-height: 1;\n}\ntextarea {\n resize: none;\n overflow: hidden; \n height: 1rem;\n}\n\ninput {\n height: 1rem;\n}\n\ninput[type=\"date\"]::-webkit-calendar-picker-indicator,\ninput[type=\"time\"]::-webkit-calendar-picker-indicator {\n filter: invert(1);\n opacity: 1;\n color: inherit;\n}\n</style>"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAGA,UAAM,OAAO;AACb,UAAM,QAAQ;AAed,QAAI,MAAM,OAAO;AACf,WAAK,gBAAgB,MAAM,KAAK;AAAA,IAClC;AACA,UAAM,WAAW,IAAI,IAAI;AACzB,UAAM,QAAQ,IAAI,IAAI;AACtB,UAAM,eAAe,IAAI,KAAK;AAE9B,aAAS,SAAS;AAChB,UAAI,CAAC,SAAS,OAAO;AACnB;AAAA,MACF;AACA,YAAM,KAAK,SAAS;AACpB,SAAG,MAAM,SAAS;AAClB,YAAM,eAAe,GAAG;AACxB,UAAI,eAAe,IAAI;AACrB,WAAG,MAAM,SAAS,eAAe;AAAA,MACnC,OAAO;AACL,WAAG,MAAM,SAAS;AAAA,MACpB;AAAA,IACF;AACA,aAAS,QAAQ;AACf,UAAI,MAAM,WAAW;AACnB,YAAI,MAAM,SAAS,cAAc,SAAS,OAAO;AAC/C,mBAAS,MAAM,MAAK;AAAA,QACtB,WAAW,MAAM,OAAO;AACtB,gBAAM,MAAM,MAAK;AAAA,QACnB;AAAA,MACF;AAAA,IACF;AACA,UAAM,MAAM,MAAM,OAAO,MAAM;AAC7B,UAAI,MAAM,SAAS,YAAY;AAC7B,iBAAS,MAAM;AAAA,MACjB;AAAA,IACF,CAAC;AACD,UAAM,MAAM,MAAM,WAAW,CAAC,WAAW;AACvC,UAAI,QAAQ;AACV,iBAAS,KAAK;AAAA,MAChB;AAAA,IACF,CAAC;AACD,cAAU,MAAM;AACd,eAAS,KAAK;AACd,eAAS,MAAM;AAAA,IACjB,CAAC;AACD,UAAM,OAAO,IAAI,MAAM,KAAK;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -1,6 +1,6 @@
1
1
  import { ref, onMounted, watchEffect, createBlock, openBlock, unref, isRef, withCtx, renderSlot, createVNode, createElementBlock, createCommentVNode, toDisplayString } from "vue";
2
- import Field from "../Field/Field.vue2.js";
3
- import _sfc_main$1 from "../Button/Button.vue.js";
2
+ import Field from "../Field/Field.vue.js";
3
+ import _sfc_main$1 from "../Button/Button.vue2.js";
4
4
  import _sfc_main$2 from "../../modules/icons/navigation/IconArrow.vue.js";
5
5
  import { useI18n } from "vue-i18n";
6
6
  const _hoisted_1 = {
@@ -1,5 +1,5 @@
1
1
  import { createElementBlock, openBlock, normalizeClass, createElementVNode, createCommentVNode, toDisplayString } from "vue";
2
- /* empty css */
2
+ /* empty css */
3
3
  import _export_sfc from "../../../../_virtual/_plugin-vue_export-helper.js";
4
4
  const _sfc_main = {
5
5
  props: {
@@ -58,4 +58,4 @@ const Loader = /* @__PURE__ */ _export_sfc(_sfc_main, [["render", _sfc_render]])
58
58
  export {
59
59
  Loader as default
60
60
  };
61
- //# sourceMappingURL=Loader.vue2.js.map
61
+ //# sourceMappingURL=Loader.vue.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Loader.vue.js","sources":["../../../../../src/components/Loader/Loader.vue"],"sourcesContent":["<template>\n <div class=\"circular-loader pos-relative z-index-1 w-100 h-100 w-max-2r h-max-2r\" :class=\"{ 'circular-loader-centered': centered }\">\n <svg viewBox=\"25 25 50 50\">\n <circle class=\"circular-loader-fill\" cx=\"50\" cy=\"50\" r=\"20\" fill=\"none\" stroke-width=\"4\" stroke-miterlimit=\"10\" />\n <circle class=\"circular-loader-circle\" cx=\"50\" cy=\"50\" r=\"20\" fill=\"none\" stroke-width=\"4\" stroke-miterlimit=\"10\" />\n </svg>\n <div v-if=\"progress\" class=\"progress-text\">{{ progress }}</div>\n <div v-if=\"status\" class=\"uppercase t-semi w-m-10r status-text\">{{ status }}</div>\n </div>\n</template>\n\n<script>\nexport default {\n props: {\n progress: {\n type: Number,\n default: null,\n },\n status: {\n type: String,\n default: null,\n },\n centered: {\n type: Boolean,\n default: true, // По умолчанию лоадер центрирован (для обратной совместимости)\n },\n },\n};\n</script>\n\n<style>\n.circular-loader-centered {\n top: calc(50% - 1rem);\n left: calc(50% - 1rem);\n}\n\n.circular-loader svg {\n animation: rotate 2s linear infinite;\n}\n\n.circular-loader-circle {\n stroke-dasharray: 1, 200;\n stroke-dashoffset: 0;\n stroke-linecap: round;\n stroke: rgb(var(--main));\n animation: dash 1.5s ease-in-out infinite;\n}\n\n.circular-loader-fill {\n stroke-linecap: round;\n stroke: rgba(var(--black),0.2);\n}\n\n.progress-text {\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n font-size: 0.8rem;\n color: rgb(var(--main));;\n}\n\n.status-text {\n position: absolute;\n top: 120%;\n left: calc(50% - 5rem);\n font-size: 0.8rem;\n width: 10rem !important;\n text-align: center;\n}\n\n@keyframes rotate {\n 100% {\n transform: rotate(360deg);\n }\n}\n\n@keyframes dash {\n 0% {\n stroke-dasharray: 1, 200;\n stroke-dashoffset: 0;\n }\n 50% {\n stroke-dasharray: 89, 200;\n stroke-dashoffset: -35;\n }\n 100% {\n stroke-dasharray: 1, 200;\n stroke-dashoffset: -124;\n }\n}\n</style>"],"names":["_createElementBlock","_normalizeClass","_createElementVNode","_toDisplayString","_createCommentVNode"],"mappings":";;;AAYA,MAAK,YAAU;AAAA,EACb,OAAO;AAAA,IACL,UAAU;AAAA,MACR,MAAM;AAAA,MACN,SAAS;AAAA;IAEX,QAAQ;AAAA,MACN,MAAM;AAAA,MACN,SAAS;AAAA;IAEX,UAAU;AAAA,MACR,MAAM;AAAA,MACN,SAAS;AAAA;AAAA;;AAGf;;EA3BA,KAAA;AAAA,EAMyB,OAAM;;;EAN/B,KAAA;AAAA,EAOuB,OAAM;;;sBAN3BA,mBAOM,OAAA;AAAA,IAPD,OADPC,eAAA,CACa,wEAAsE,EAAA,4BAAuC,OAAA,UAAQ,CAAA;AAAA;8BAC9HC,mBAGM,OAAA,EAHD,SAAQ,iBAAa;AAAA,MACxBA,mBAAkH,UAAA;AAAA,QAA1G,OAAM;AAAA,QAAuB,IAAG;AAAA,QAAK,IAAG;AAAA,QAAK,GAAE;AAAA,QAAK,MAAK;AAAA,QAAO,gBAAa;AAAA,QAAI,qBAAkB;AAAA;MAC3GA,mBAAoH,UAAA;AAAA,QAA5G,OAAM;AAAA,QAAyB,IAAG;AAAA,QAAK,IAAG;AAAA,QAAK,GAAE;AAAA,QAAK,MAAK;AAAA,QAAO,gBAAa;AAAA,QAAI,qBAAkB;AAAA;;IAEpG,OAAA,yBAAXF,mBAA+D,OAA/D,YAA+DG,gBAAjB,OAAA,QAAQ,GAAA,CAAA,KAN1DC,mBAAA,IAAA,IAAA;AAAA,IAOe,OAAA,uBAAXJ,mBAAkF,OAAlF,YAAkFG,gBAAf,OAAA,MAAM,GAAA,CAAA,KAP7EC,mBAAA,IAAA,IAAA;AAAA;;;"}
@@ -1,6 +1,6 @@
1
1
  import { ref, onMounted, watchEffect, createElementBlock, openBlock, createElementVNode, createVNode, Transition, withCtx, createBlock } from "vue";
2
2
  import { Loader } from "../../../../node_modules/.pnpm/@googlemaps_js-api-loader@1.16.8/node_modules/@googlemaps/js-api-loader/dist/index.js";
3
- import Loader$1 from "../Loader/Loader.vue2.js";
3
+ import Loader$1 from "../Loader/Loader.vue.js";
4
4
  /* empty css */
5
5
  const _hoisted_1 = { class: "pos-relative" };
6
6
  const _hoisted_2 = {
@@ -1,5 +1,5 @@
1
1
  import { ref, computed, onMounted, onUnmounted, createElementBlock, openBlock, createCommentVNode, mergeProps, createElementVNode, createVNode } from "vue";
2
- import Loader from "../Loader/Loader.vue2.js";
2
+ import Loader from "../Loader/Loader.vue.js";
3
3
  import _sfc_main$1 from "../../modules/icons/entities/IconGallery.vue.js";
4
4
  /* empty css */
5
5
  import _export_sfc from "../../../../_virtual/_plugin-vue_export-helper.js";
@@ -1,6 +1,6 @@
1
1
  import { ref, computed, watch, createElementBlock, openBlock, Fragment, withDirectives, createVNode, normalizeClass, withModifiers, createCommentVNode, createElementVNode, toDisplayString, Transition, withCtx, renderList, vShow, unref, nextTick } from "vue";
2
2
  import clickOutside from "../FieldPhone/click-outside.js";
3
- /* empty css */
3
+ /* empty css */
4
4
  import _export_sfc from "../../../../_virtual/_plugin-vue_export-helper.js";
5
5
  const _hoisted_1 = {
6
6
  key: 0,
@@ -131,4 +131,4 @@ const Select = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-849
131
131
  export {
132
132
  Select as default
133
133
  };
134
- //# sourceMappingURL=Select.vue2.js.map
134
+ //# sourceMappingURL=Select.vue.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Select.vue.js","sources":["../../../../../src/components/Select/Select.vue"],"sourcesContent":["<template>\n <!-- Input Wrapper -->\n <div \n ref=\"fieldWrapper\"\n tabindex=\"0\"\n @click.stop=\"toggleMenu\" \n v-click-outside=\"clickedOutside\" \n :class=\"$attrs.class\" \n class=\"cursor-pointer field-wrapper flex-v-center flex-nowrap flex pos-relative\"\n >\n <!-- Label -->\n <span v-if=\"label\" class=\"t-transp mn-r-small\">{{label}}</span>\n \n <!-- Input -->\n <span>\n {{ optionsSelected ? (optionsSelected.name || optionsSelected[props.value] || optionsSelected) : placeholder }}\n </span>\n <!-- Dropdown menu -->\n <transition mode=\"out-in\" name=\"TransitionTranslateY\">\n <ul \n v-show=\"showMenu\" \n class=\"bs-black pos-absolute pos-t-100 pos-l-0 z-index-5 pd-small radius-small bg-white mn-t-thin w-100\"\n style=\"min-width: max-content;\"\n >\n <li @click.stop=\"selectOption(option)\" v-for=\"option in optionsListed\" class=\"radius-thin hover-bg-light pd-thin text-box-trim\">\n <span v-if=\"option\" class=\"w-100\">\n {{ option.name || option[props.value] || option }}\n </span>\n </li>\n </ul>\n </transition>\n </div>\n <!-- Validation -->\n <transition mode=\"out-in\" name=\"fade\">\n <div v-if=\"validation\" class=\"mn-t-thin invalid-feedback\">\n * {{validation.message}}\n </div>\n </transition>\n</template>\n<script setup>\nimport { ref, computed, watch, nextTick } from 'vue'\nimport clickOutside from '../FieldPhone/click-outside.js';\nlet vClickOutside = clickOutside\nconst emit = defineEmits([\n 'update:select', \n 'focus', \n 'blur'\n])\nconst props = defineProps({\n label: String,\n placeholder: { type: String, default: 'Please select an item' },\n select: [String, Object],\n property: String,\n value: String,\n options: { type: Array, default: () => [] },\n validation: Boolean,\n})\nconst showMenu = ref(false)\nconst fieldWrapper = ref(null)\nconst optionsSelected = ref(\n props.property \n ? findObjectByValue(props.select, props.property, props.options) \n : props.select\n)\nconst optionsListed = computed(() => {\n return props.select \n ? props.options.filter(option => option !== props.select) \n : props.options\n})\nwatch(() => props.select, (newSelect) => {\n optionsSelected.value = \n props.property \n ? findObjectByValue(props.select, props.property, props.options) \n : props.select;\n});\nconst toggleMenu = async () => {\n showMenu.value = !showMenu.value\n \n if (showMenu.value) {\n await nextTick()\n fieldWrapper.value?.focus()\n emit('focus')\n } else {\n emit('blur')\n }\n}\nfunction clickedOutside () {\n showMenu.value = false\n}\nconst selectOption = option => {\n optionsSelected.value = option\n \n toggleMenu()\n if (props.property) { \n emit('update:select', optionsSelected.value[props.property])\n } else {\n emit('update:select', optionsSelected.value)\n }\n}\nfunction findObjectByValue (value, property, objects) {\n for (const object of objects) {\n if (object[property] === value || object === value) {\n return object;\n }\n }\n return null;\n}\n</script>\n<style lang=\"scss\" scoped>\n li {\n list-style-type: none;\n }\n ul li {\n line-height: 2;\n }\n .field-wrapper:focus {\n outline: none;\n }\n</style>"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA0CA,QAAI,gBAAgB;AACpB,UAAM,OAAO;AAKb,UAAM,QAAQ;AASd,UAAM,WAAW,IAAI,KAAK;AAC1B,UAAM,eAAe,IAAI,IAAI;AAC7B,UAAM,kBAAkB;AAAA,MACtB,MAAM,WACJ,kBAAkB,MAAM,QAAQ,MAAM,UAAU,MAAM,OAAO,IAC7D,MAAM;AAAA,IACV;AACA,UAAM,gBAAgB,SAAS,MAAM;AACnC,aAAO,MAAM,SACX,MAAM,QAAQ,OAAO,YAAU,WAAW,MAAM,MAAM,IACtD,MAAM;AAAA,IACV,CAAC;AACD,UAAM,MAAM,MAAM,QAAQ,CAAC,cAAc;AACvC,sBAAgB,QAChB,MAAM,WACJ,kBAAkB,MAAM,QAAQ,MAAM,UAAU,MAAM,OAAO,IAC7D,MAAM;AAAA,IACV,CAAC;AACD,UAAM,aAAa,YAAY;AAC7B,eAAS,QAAQ,CAAC,SAAS;AAE3B,UAAI,SAAS,OAAO;AAClB,cAAM,SAAQ;AACd,qBAAa,OAAO,MAAK;AACzB,aAAK,OAAO;AAAA,MACd,OAAO;AACL,aAAK,MAAM;AAAA,MACb;AAAA,IACF;AACA,aAAS,iBAAkB;AACzB,eAAS,QAAQ;AAAA,IACnB;AACA,UAAM,eAAe,YAAU;AAC7B,sBAAgB,QAAQ;AAExB,iBAAU;AACV,UAAI,MAAM,UAAU;AAClB,aAAK,iBAAiB,gBAAgB,MAAM,MAAM,QAAQ,CAAC;AAAA,MAC7D,OAAO;AACL,aAAK,iBAAiB,gBAAgB,KAAK;AAAA,MAC7C;AAAA,IACF;AACA,aAAS,kBAAmB,OAAO,UAAU,SAAS;AACpD,iBAAW,UAAU,SAAS;AAC5B,YAAI,OAAO,QAAQ,MAAM,SAAS,WAAW,OAAO;AAClD,iBAAO;AAAA,QACT;AAAA,MACF;AACA,aAAO;AAAA,IACT;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -1,5 +1,5 @@
1
1
  import { ref, computed, watch, onMounted, createElementBlock, openBlock, withKeys, normalizeClass, withModifiers, renderSlot, createElementVNode, createVNode, createCommentVNode, withDirectives, Fragment, renderList, toDisplayString, vShow, Transition, withCtx, normalizeStyle, createTextVNode, nextTick } from "vue";
2
- /* empty css */
2
+ /* empty css */
3
3
  const _hoisted_1 = ["tabindex", "onKeydown", "onKeypress", "aria-owns"];
4
4
  const _hoisted_2 = { class: "multiselect__tags-wrap" };
5
5
  const _hoisted_3 = { class: "multiselect__tag" };
@@ -622,4 +622,4 @@ const _sfc_main = {
622
622
  export {
623
623
  _sfc_main as default
624
624
  };
625
- //# sourceMappingURL=SelectMulti.vue.js.map
625
+ //# sourceMappingURL=SelectMulti.vue2.js.map