@ozdao/prometheus-framework 0.2.221 → 0.2.223

Sign up to get free protection for your applications and to get access to all the features.
Files changed (491) hide show
  1. package/dist/auth.server.js +4 -4
  2. package/dist/auth.server.mjs +4 -4
  3. package/dist/builder.js +72 -60
  4. package/dist/builder.mjs +72 -60
  5. package/dist/community.server.js +9 -4
  6. package/dist/community.server.mjs +9 -4
  7. package/dist/events.server.js +14 -24
  8. package/dist/events.server.mjs +14 -24
  9. package/dist/files.server.js +1 -1
  10. package/dist/files.server.mjs +1 -1
  11. package/dist/gallery.server.js +42 -76
  12. package/dist/gallery.server.mjs +41 -75
  13. package/dist/index-CsS7qx1d.js +243 -0
  14. package/dist/index-UIHE6Rk3.mjs +244 -0
  15. package/dist/main.css +1 -1
  16. package/dist/node_modules/@capacitor/core/dist/index.cjs +529 -0
  17. package/dist/node_modules/@capacitor/core/dist/index.cjs.map +1 -0
  18. package/dist/node_modules/@capacitor/core/dist/index.js +530 -0
  19. package/dist/node_modules/@capacitor/core/dist/index.js.map +1 -0
  20. package/dist/node_modules/@capacitor-mlkit/barcode-scanning/dist/esm/definitions.cjs +51 -0
  21. package/dist/node_modules/@capacitor-mlkit/barcode-scanning/dist/esm/definitions.cjs.map +1 -0
  22. package/dist/node_modules/@capacitor-mlkit/barcode-scanning/dist/esm/definitions.js +55 -0
  23. package/dist/node_modules/@capacitor-mlkit/barcode-scanning/dist/esm/definitions.js.map +1 -0
  24. package/dist/node_modules/@capacitor-mlkit/barcode-scanning/dist/esm/index.cjs +25 -0
  25. package/dist/node_modules/@capacitor-mlkit/barcode-scanning/dist/esm/index.cjs.map +1 -0
  26. package/dist/node_modules/@capacitor-mlkit/barcode-scanning/dist/esm/index.js +13 -0
  27. package/dist/node_modules/@capacitor-mlkit/barcode-scanning/dist/esm/index.js.map +1 -0
  28. package/dist/node_modules/@capacitor-mlkit/barcode-scanning/dist/esm/web.cjs +67 -0
  29. package/dist/node_modules/@capacitor-mlkit/barcode-scanning/dist/esm/web.cjs.map +1 -0
  30. package/dist/node_modules/@capacitor-mlkit/barcode-scanning/dist/esm/web.js +67 -0
  31. package/dist/node_modules/@capacitor-mlkit/barcode-scanning/dist/esm/web.js.map +1 -0
  32. package/dist/node_modules/@unhead/shared/dist/index.cjs +7 -0
  33. package/dist/node_modules/@unhead/shared/dist/index.cjs.map +1 -0
  34. package/dist/node_modules/@unhead/shared/dist/index.js +7 -0
  35. package/dist/node_modules/@unhead/shared/dist/index.js.map +1 -0
  36. package/dist/node_modules/@unhead/ssr/dist/index.cjs +87 -0
  37. package/dist/node_modules/@unhead/ssr/dist/index.cjs.map +1 -0
  38. package/dist/node_modules/@unhead/ssr/dist/index.js +87 -0
  39. package/dist/node_modules/@unhead/ssr/dist/index.js.map +1 -0
  40. package/dist/orders.server.js +2 -2
  41. package/dist/orders.server.mjs +2 -2
  42. package/dist/organizations.server.js +174 -95
  43. package/dist/organizations.server.mjs +174 -95
  44. package/dist/pages.server.js +1 -1
  45. package/dist/pages.server.mjs +1 -1
  46. package/dist/products.server.js +119 -266
  47. package/dist/products.server.mjs +119 -266
  48. package/dist/prometheus-framework/node_modules/@vue/server-renderer/dist/server-renderer.esm-bundler.cjs +814 -0
  49. package/dist/prometheus-framework/node_modules/@vue/server-renderer/dist/server-renderer.esm-bundler.cjs.map +1 -0
  50. package/dist/prometheus-framework/node_modules/@vue/server-renderer/dist/server-renderer.esm-bundler.js +814 -0
  51. package/dist/prometheus-framework/node_modules/@vue/server-renderer/dist/server-renderer.esm-bundler.js.map +1 -0
  52. package/dist/prometheus-framework/node_modules/@vue/shared/dist/shared.esm-bundler.cjs +210 -0
  53. package/dist/prometheus-framework/node_modules/@vue/shared/dist/shared.esm-bundler.cjs.map +1 -0
  54. package/dist/prometheus-framework/node_modules/@vue/shared/dist/shared.esm-bundler.js +210 -0
  55. package/dist/prometheus-framework/node_modules/@vue/shared/dist/shared.esm-bundler.js.map +1 -0
  56. package/dist/prometheus-framework/src/components/Button/Button.vue.cjs +1 -2
  57. package/dist/prometheus-framework/src/components/Button/Button.vue.cjs.map +1 -1
  58. package/dist/prometheus-framework/src/components/Button/Button.vue.js +1 -2
  59. package/dist/prometheus-framework/src/components/Button/Button.vue.js.map +1 -1
  60. package/dist/prometheus-framework/src/components/Feed/Feed.vue.cjs +26 -41
  61. package/dist/prometheus-framework/src/components/Feed/Feed.vue.cjs.map +1 -1
  62. package/dist/prometheus-framework/src/components/Feed/Feed.vue.js +27 -42
  63. package/dist/prometheus-framework/src/components/Feed/Feed.vue.js.map +1 -1
  64. package/dist/prometheus-framework/src/components/FieldBig/FieldBig.vue.cjs +1 -1
  65. package/dist/prometheus-framework/src/components/FieldBig/FieldBig.vue.js +1 -1
  66. package/dist/prometheus-framework/src/components/FieldTags/BlockTags.vue.cjs +6 -8
  67. package/dist/prometheus-framework/src/components/FieldTags/BlockTags.vue.cjs.map +1 -1
  68. package/dist/prometheus-framework/src/components/FieldTags/BlockTags.vue.js +6 -8
  69. package/dist/prometheus-framework/src/components/FieldTags/BlockTags.vue.js.map +1 -1
  70. package/dist/prometheus-framework/src/components/Slider/Slider.vue.cjs +1 -1
  71. package/dist/prometheus-framework/src/components/Slider/Slider.vue.js +1 -1
  72. package/dist/prometheus-framework/src/components/UploadImage/UploadImage.vue.cjs +2 -1
  73. package/dist/prometheus-framework/src/components/UploadImage/UploadImage.vue.cjs.map +1 -1
  74. package/dist/prometheus-framework/src/components/UploadImage/UploadImage.vue.js +2 -1
  75. package/dist/prometheus-framework/src/components/UploadImage/UploadImage.vue.js.map +1 -1
  76. package/dist/prometheus-framework/src/components/UploadImageMultiple/UploadImageMultiple.vue.cjs +1 -1
  77. package/dist/prometheus-framework/src/components/UploadImageMultiple/UploadImageMultiple.vue.js +1 -1
  78. package/dist/prometheus-framework/src/modules/auth/views/components/layouts/Auth.vue.cjs +2 -2
  79. package/dist/prometheus-framework/src/modules/auth/views/components/layouts/Auth.vue.js +2 -2
  80. package/dist/prometheus-framework/src/modules/auth/views/components/pages/EnterCode.vue.cjs +1 -1
  81. package/dist/prometheus-framework/src/modules/auth/views/components/pages/EnterCode.vue.js +1 -1
  82. package/dist/prometheus-framework/src/modules/auth/views/components/pages/EnterPassword.vue.cjs +1 -1
  83. package/dist/prometheus-framework/src/modules/auth/views/components/pages/EnterPassword.vue.js +1 -1
  84. package/dist/prometheus-framework/src/modules/auth/views/components/pages/Invite.vue.cjs +1 -1
  85. package/dist/prometheus-framework/src/modules/auth/views/components/pages/Invite.vue.js +1 -1
  86. package/dist/prometheus-framework/src/modules/auth/views/components/pages/ResetPassword.vue.cjs +1 -1
  87. package/dist/prometheus-framework/src/modules/auth/views/components/pages/ResetPassword.vue.js +1 -1
  88. package/dist/prometheus-framework/src/modules/auth/views/components/pages/SignIn.vue.cjs +2 -1
  89. package/dist/prometheus-framework/src/modules/auth/views/components/pages/SignIn.vue.cjs.map +1 -1
  90. package/dist/prometheus-framework/src/modules/auth/views/components/pages/SignIn.vue.js +2 -1
  91. package/dist/prometheus-framework/src/modules/auth/views/components/pages/SignIn.vue.js.map +1 -1
  92. package/dist/prometheus-framework/src/modules/auth/views/components/pages/SignUp.vue.cjs +1 -1
  93. package/dist/prometheus-framework/src/modules/auth/views/components/pages/SignUp.vue.js +1 -1
  94. package/dist/prometheus-framework/src/modules/auth/views/middlewares/auth.validation.cjs +5 -0
  95. package/dist/prometheus-framework/src/modules/auth/views/middlewares/auth.validation.cjs.map +1 -1
  96. package/dist/prometheus-framework/src/modules/auth/views/middlewares/auth.validation.js +5 -0
  97. package/dist/prometheus-framework/src/modules/auth/views/middlewares/auth.validation.js.map +1 -1
  98. package/dist/prometheus-framework/src/modules/auth/views/middlewares/ownership.validation.cjs +44 -0
  99. package/dist/prometheus-framework/src/modules/auth/views/middlewares/ownership.validation.cjs.map +1 -0
  100. package/dist/prometheus-framework/src/modules/auth/views/middlewares/ownership.validation.js +44 -0
  101. package/dist/prometheus-framework/src/modules/auth/views/middlewares/ownership.validation.js.map +1 -0
  102. package/dist/prometheus-framework/src/modules/auth/views/store/auth.cjs +37 -35
  103. package/dist/prometheus-framework/src/modules/auth/views/store/auth.cjs.map +1 -1
  104. package/dist/prometheus-framework/src/modules/auth/views/store/auth.js +33 -31
  105. package/dist/prometheus-framework/src/modules/auth/views/store/auth.js.map +1 -1
  106. package/dist/prometheus-framework/src/modules/auth/views/store/twofa.cjs +3 -5
  107. package/dist/prometheus-framework/src/modules/auth/views/store/twofa.cjs.map +1 -1
  108. package/dist/prometheus-framework/src/modules/auth/views/store/twofa.js +2 -4
  109. package/dist/prometheus-framework/src/modules/auth/views/store/twofa.js.map +1 -1
  110. package/dist/prometheus-framework/src/modules/auth/views/validations/inputs.validation.cjs +8 -5
  111. package/dist/prometheus-framework/src/modules/auth/views/validations/inputs.validation.cjs.map +1 -1
  112. package/dist/prometheus-framework/src/modules/auth/views/validations/inputs.validation.js +8 -5
  113. package/dist/prometheus-framework/src/modules/auth/views/validations/inputs.validation.js.map +1 -1
  114. package/dist/prometheus-framework/src/modules/community/components/blocks/CardBlogpost.vue.cjs +4 -2
  115. package/dist/prometheus-framework/src/modules/community/components/blocks/CardBlogpost.vue.cjs.map +1 -1
  116. package/dist/prometheus-framework/src/modules/community/components/blocks/CardBlogpost.vue.js +4 -2
  117. package/dist/prometheus-framework/src/modules/community/components/blocks/CardBlogpost.vue.js.map +1 -1
  118. package/dist/prometheus-framework/src/modules/community/components/layouts/Community.vue.cjs +13 -9
  119. package/dist/prometheus-framework/src/modules/community/components/layouts/Community.vue.cjs.map +1 -1
  120. package/dist/prometheus-framework/src/modules/community/components/layouts/Community.vue.js +14 -10
  121. package/dist/prometheus-framework/src/modules/community/components/layouts/Community.vue.js.map +1 -1
  122. package/dist/prometheus-framework/src/modules/community/components/pages/BlogPost.vue.cjs +53 -40
  123. package/dist/prometheus-framework/src/modules/community/components/pages/BlogPost.vue.cjs.map +1 -1
  124. package/dist/prometheus-framework/src/modules/community/components/pages/BlogPost.vue.js +58 -45
  125. package/dist/prometheus-framework/src/modules/community/components/pages/BlogPost.vue.js.map +1 -1
  126. package/dist/prometheus-framework/src/modules/community/components/pages/Community.vue.cjs +2 -2
  127. package/dist/prometheus-framework/src/modules/community/components/pages/Community.vue.js +2 -2
  128. package/dist/prometheus-framework/src/modules/community/components/pages/CreateBlogPost.vue.cjs +1 -1
  129. package/dist/prometheus-framework/src/modules/community/components/pages/CreateBlogPost.vue.cjs.map +1 -1
  130. package/dist/prometheus-framework/src/modules/community/components/pages/CreateBlogPost.vue.js +1 -1
  131. package/dist/prometheus-framework/src/modules/community/components/pages/CreateBlogPost.vue.js.map +1 -1
  132. package/dist/prometheus-framework/src/modules/community/components/sections/Comments.vue.cjs +16 -15
  133. package/dist/prometheus-framework/src/modules/community/components/sections/Comments.vue.cjs.map +1 -1
  134. package/dist/prometheus-framework/src/modules/community/components/sections/Comments.vue.js +16 -15
  135. package/dist/prometheus-framework/src/modules/community/components/sections/Comments.vue.js.map +1 -1
  136. package/dist/prometheus-framework/src/modules/community/components/sections/HotPosts.vue.cjs +4 -4
  137. package/dist/prometheus-framework/src/modules/community/components/sections/HotPosts.vue.js +4 -4
  138. package/dist/prometheus-framework/src/modules/community/router/blogposts.cjs +47 -43
  139. package/dist/prometheus-framework/src/modules/community/router/blogposts.cjs.map +1 -1
  140. package/dist/prometheus-framework/src/modules/community/router/blogposts.js +47 -43
  141. package/dist/prometheus-framework/src/modules/community/router/blogposts.js.map +1 -1
  142. package/dist/prometheus-framework/src/modules/community/store/blogposts.cjs +13 -20
  143. package/dist/prometheus-framework/src/modules/community/store/blogposts.cjs.map +1 -1
  144. package/dist/prometheus-framework/src/modules/community/store/blogposts.js +9 -16
  145. package/dist/prometheus-framework/src/modules/community/store/blogposts.js.map +1 -1
  146. package/dist/prometheus-framework/src/modules/community/store/reactions.cjs +5 -9
  147. package/dist/prometheus-framework/src/modules/community/store/reactions.cjs.map +1 -1
  148. package/dist/prometheus-framework/src/modules/community/store/reactions.js +1 -5
  149. package/dist/prometheus-framework/src/modules/community/store/reactions.js.map +1 -1
  150. package/dist/prometheus-framework/src/modules/constructor/components/elements/Embed.vue.cjs +1 -1
  151. package/dist/prometheus-framework/src/modules/constructor/components/elements/Embed.vue.js +1 -1
  152. package/dist/prometheus-framework/src/modules/events/components/blocks/CardEvent.vue.cjs +1 -1
  153. package/dist/prometheus-framework/src/modules/events/components/blocks/CardEvent.vue.js +1 -1
  154. package/dist/prometheus-framework/src/modules/events/components/elements/ButtonCheck.vue.cjs +29 -54
  155. package/dist/prometheus-framework/src/modules/events/components/elements/ButtonCheck.vue.cjs.map +1 -1
  156. package/dist/prometheus-framework/src/modules/events/components/elements/ButtonCheck.vue.js +30 -55
  157. package/dist/prometheus-framework/src/modules/events/components/elements/ButtonCheck.vue.js.map +1 -1
  158. package/dist/prometheus-framework/src/modules/events/components/pages/EditEvent.vue.cjs +163 -134
  159. package/dist/prometheus-framework/src/modules/events/components/pages/EditEvent.vue.cjs.map +1 -1
  160. package/dist/prometheus-framework/src/modules/events/components/pages/EditEvent.vue.js +165 -136
  161. package/dist/prometheus-framework/src/modules/events/components/pages/EditEvent.vue.js.map +1 -1
  162. package/dist/prometheus-framework/src/modules/events/components/pages/EditEventTickets.vue.cjs +1 -1
  163. package/dist/prometheus-framework/src/modules/events/components/pages/EditEventTickets.vue.js +1 -1
  164. package/dist/prometheus-framework/src/modules/events/components/pages/Event.vue.cjs +124 -135
  165. package/dist/prometheus-framework/src/modules/events/components/pages/Event.vue.cjs.map +1 -1
  166. package/dist/prometheus-framework/src/modules/events/components/pages/Event.vue.js +133 -144
  167. package/dist/prometheus-framework/src/modules/events/components/pages/Event.vue.js.map +1 -1
  168. package/dist/prometheus-framework/src/modules/events/components/pages/Events.vue.cjs.map +1 -1
  169. package/dist/prometheus-framework/src/modules/events/components/pages/Events.vue.js.map +1 -1
  170. package/dist/prometheus-framework/src/modules/events/components/pages/EventsBackoffice.vue.cjs +96 -0
  171. package/dist/prometheus-framework/src/modules/events/components/pages/EventsBackoffice.vue.cjs.map +1 -0
  172. package/dist/prometheus-framework/src/modules/events/components/pages/EventsBackoffice.vue.js +96 -0
  173. package/dist/prometheus-framework/src/modules/events/components/pages/EventsBackoffice.vue.js.map +1 -0
  174. package/dist/prometheus-framework/src/modules/events/components/sections/Feed.vue.cjs +1 -1
  175. package/dist/prometheus-framework/src/modules/events/components/sections/Feed.vue.js +1 -1
  176. package/dist/prometheus-framework/src/modules/events/components/sections/HeroEvent.vue.cjs +39 -25
  177. package/dist/prometheus-framework/src/modules/events/components/sections/HeroEvent.vue.cjs.map +1 -1
  178. package/dist/prometheus-framework/src/modules/events/components/sections/HeroEvent.vue.js +40 -26
  179. package/dist/prometheus-framework/src/modules/events/components/sections/HeroEvent.vue.js.map +1 -1
  180. package/dist/prometheus-framework/src/modules/events/components/sections/List.vue.cjs +1 -1
  181. package/dist/prometheus-framework/src/modules/events/components/sections/List.vue.js +1 -1
  182. package/dist/prometheus-framework/src/modules/events/components/sections/SectionPreviousEvents.vue.cjs +4 -3
  183. package/dist/prometheus-framework/src/modules/events/components/sections/SectionPreviousEvents.vue.cjs.map +1 -1
  184. package/dist/prometheus-framework/src/modules/events/components/sections/SectionPreviousEvents.vue.js +4 -3
  185. package/dist/prometheus-framework/src/modules/events/components/sections/SectionPreviousEvents.vue.js.map +1 -1
  186. package/dist/prometheus-framework/src/modules/events/router/events.cjs +16 -5
  187. package/dist/prometheus-framework/src/modules/events/router/events.cjs.map +1 -1
  188. package/dist/prometheus-framework/src/modules/events/router/events.js +16 -5
  189. package/dist/prometheus-framework/src/modules/events/router/events.js.map +1 -1
  190. package/dist/prometheus-framework/src/modules/events/store/events.cjs +5 -6
  191. package/dist/prometheus-framework/src/modules/events/store/events.cjs.map +1 -1
  192. package/dist/prometheus-framework/src/modules/events/store/events.js +1 -2
  193. package/dist/prometheus-framework/src/modules/events/store/events.js.map +1 -1
  194. package/dist/prometheus-framework/src/modules/gallery/components/sections/BackofficeGallery.vue.cjs +20 -11
  195. package/dist/prometheus-framework/src/modules/gallery/components/sections/BackofficeGallery.vue.cjs.map +1 -1
  196. package/dist/prometheus-framework/src/modules/gallery/components/sections/BackofficeGallery.vue.js +20 -11
  197. package/dist/prometheus-framework/src/modules/gallery/components/sections/BackofficeGallery.vue.js.map +1 -1
  198. package/dist/prometheus-framework/src/modules/gallery/router/gallery.backoffice.router.cjs +5 -2
  199. package/dist/prometheus-framework/src/modules/gallery/router/gallery.backoffice.router.cjs.map +1 -1
  200. package/dist/prometheus-framework/src/modules/gallery/router/gallery.backoffice.router.js +5 -2
  201. package/dist/prometheus-framework/src/modules/gallery/router/gallery.backoffice.router.js.map +1 -1
  202. package/dist/prometheus-framework/src/modules/globals/globals.client.cjs +2 -0
  203. package/dist/prometheus-framework/src/modules/globals/globals.client.cjs.map +1 -1
  204. package/dist/prometheus-framework/src/modules/globals/globals.client.js +2 -0
  205. package/dist/prometheus-framework/src/modules/globals/globals.client.js.map +1 -1
  206. package/dist/prometheus-framework/src/modules/globals/views/classes/globals.store.cjs +4 -3
  207. package/dist/prometheus-framework/src/modules/globals/views/classes/globals.store.cjs.map +1 -1
  208. package/dist/prometheus-framework/src/modules/globals/views/classes/globals.store.js +4 -3
  209. package/dist/prometheus-framework/src/modules/globals/views/classes/globals.store.js.map +1 -1
  210. package/dist/prometheus-framework/src/modules/globals/views/components/blocks/BlockFilter.vue.cjs +1 -1
  211. package/dist/prometheus-framework/src/modules/globals/views/components/blocks/BlockFilter.vue.js +1 -1
  212. package/dist/prometheus-framework/src/modules/globals/views/components/blocks/BlockSearch.vue.cjs +1 -1
  213. package/dist/prometheus-framework/src/modules/globals/views/components/blocks/BlockSearch.vue.js +1 -1
  214. package/dist/prometheus-framework/src/modules/globals/views/components/blocks/Card.vue.cjs +64 -0
  215. package/dist/prometheus-framework/src/modules/globals/views/components/blocks/Card.vue.cjs.map +1 -0
  216. package/dist/prometheus-framework/src/modules/globals/views/components/blocks/Card.vue.js +64 -0
  217. package/dist/prometheus-framework/src/modules/globals/views/components/blocks/Card.vue.js.map +1 -0
  218. package/dist/prometheus-framework/src/modules/globals/views/components/blocks/CardHeader.vue.cjs +3 -3
  219. package/dist/prometheus-framework/src/modules/globals/views/components/blocks/CardHeader.vue.cjs.map +1 -1
  220. package/dist/prometheus-framework/src/modules/globals/views/components/blocks/CardHeader.vue.js +3 -3
  221. package/dist/prometheus-framework/src/modules/globals/views/components/blocks/CardHeader.vue.js.map +1 -1
  222. package/dist/prometheus-framework/src/modules/globals/views/components/layouts/App.vue.cjs +1 -0
  223. package/dist/prometheus-framework/src/modules/globals/views/components/layouts/App.vue.cjs.map +1 -1
  224. package/dist/prometheus-framework/src/modules/globals/views/components/layouts/App.vue.js +1 -0
  225. package/dist/prometheus-framework/src/modules/globals/views/components/layouts/App.vue.js.map +1 -1
  226. package/dist/prometheus-framework/src/modules/globals/views/components/layouts/Client.vue.cjs +1 -19
  227. package/dist/prometheus-framework/src/modules/globals/views/components/layouts/Client.vue.cjs.map +1 -1
  228. package/dist/prometheus-framework/src/modules/globals/views/components/layouts/Client.vue.js +1 -19
  229. package/dist/prometheus-framework/src/modules/globals/views/components/layouts/Client.vue.js.map +1 -1
  230. package/dist/prometheus-framework/src/modules/globals/views/components/partials/LocationSelection.vue.cjs +2 -2
  231. package/dist/prometheus-framework/src/modules/globals/views/components/partials/LocationSelection.vue.js +2 -2
  232. package/dist/prometheus-framework/src/modules/globals/views/store/globals.cjs +3 -2
  233. package/dist/prometheus-framework/src/modules/globals/views/store/globals.cjs.map +1 -1
  234. package/dist/prometheus-framework/src/modules/globals/views/store/globals.js +3 -2
  235. package/dist/prometheus-framework/src/modules/globals/views/store/globals.js.map +1 -1
  236. package/dist/prometheus-framework/src/modules/globals/views/utils/axios-instance.cjs +17 -0
  237. package/dist/prometheus-framework/src/modules/globals/views/utils/axios-instance.cjs.map +1 -0
  238. package/dist/prometheus-framework/src/modules/globals/views/utils/axios-instance.js +17 -0
  239. package/dist/prometheus-framework/src/modules/globals/views/utils/axios-instance.js.map +1 -0
  240. package/dist/prometheus-framework/src/modules/globals/views/utils/vue-app-renderer.cjs +57 -0
  241. package/dist/prometheus-framework/src/modules/globals/views/utils/vue-app-renderer.cjs.map +1 -0
  242. package/dist/prometheus-framework/src/modules/globals/views/utils/vue-app-renderer.js +57 -0
  243. package/dist/prometheus-framework/src/modules/globals/views/utils/vue-app-renderer.js.map +1 -0
  244. package/dist/prometheus-framework/src/modules/landing/components/sections/SectionGuide.vue.cjs +1 -1
  245. package/dist/prometheus-framework/src/modules/landing/components/sections/SectionGuide.vue.js +1 -1
  246. package/dist/prometheus-framework/src/modules/legal/components/pages/Legal.vue.cjs +2 -2
  247. package/dist/prometheus-framework/src/modules/legal/components/pages/Legal.vue.js +2 -2
  248. package/dist/prometheus-framework/src/modules/orders/components/pages/OrderCreateBackoffice.vue.cjs +1 -1
  249. package/dist/prometheus-framework/src/modules/orders/components/pages/OrderCreateBackoffice.vue.js +1 -1
  250. package/dist/prometheus-framework/src/modules/orders/components/sections/FormAddCustomer.vue.cjs +1 -1
  251. package/dist/prometheus-framework/src/modules/orders/components/sections/FormAddCustomer.vue.js +1 -1
  252. package/dist/prometheus-framework/src/modules/orders/components/sections/FormCustomerDetails.vue.cjs +1 -1
  253. package/dist/prometheus-framework/src/modules/orders/components/sections/FormCustomerDetails.vue.js +1 -1
  254. package/dist/prometheus-framework/src/modules/orders/components/sections/FormDelivery.vue.cjs +3 -3
  255. package/dist/prometheus-framework/src/modules/orders/components/sections/FormDelivery.vue.js +3 -3
  256. package/dist/prometheus-framework/src/modules/orders/store/orders.cjs +6 -7
  257. package/dist/prometheus-framework/src/modules/orders/store/orders.cjs.map +1 -1
  258. package/dist/prometheus-framework/src/modules/orders/store/orders.js +1 -2
  259. package/dist/prometheus-framework/src/modules/orders/store/orders.js.map +1 -1
  260. package/dist/prometheus-framework/src/modules/organizations/components/blocks/CardDepartment.vue.cjs +1 -1
  261. package/dist/prometheus-framework/src/modules/organizations/components/blocks/CardDepartment.vue.js +1 -1
  262. package/dist/prometheus-framework/src/modules/organizations/components/blocks/CardOrganization.vue.cjs +1 -1
  263. package/dist/prometheus-framework/src/modules/organizations/components/blocks/CardOrganization.vue.js +1 -1
  264. package/dist/prometheus-framework/src/modules/organizations/components/pages/Department.vue.cjs +1 -1
  265. package/dist/prometheus-framework/src/modules/organizations/components/pages/Department.vue.js +1 -1
  266. package/dist/prometheus-framework/src/modules/organizations/components/pages/DepartmentEdit.vue.cjs +60 -23
  267. package/dist/prometheus-framework/src/modules/organizations/components/pages/DepartmentEdit.vue.cjs.map +1 -1
  268. package/dist/prometheus-framework/src/modules/organizations/components/pages/DepartmentEdit.vue.js +60 -23
  269. package/dist/prometheus-framework/src/modules/organizations/components/pages/DepartmentEdit.vue.js.map +1 -1
  270. package/dist/prometheus-framework/src/modules/organizations/components/pages/OrganizationBackoffice.vue.cjs +2 -1
  271. package/dist/prometheus-framework/src/modules/organizations/components/pages/OrganizationBackoffice.vue.cjs.map +1 -1
  272. package/dist/prometheus-framework/src/modules/organizations/components/pages/OrganizationBackoffice.vue.js +3 -2
  273. package/dist/prometheus-framework/src/modules/organizations/components/pages/OrganizationBackoffice.vue.js.map +1 -1
  274. package/dist/prometheus-framework/src/modules/organizations/components/pages/OrganizationEdit.vue.cjs +1 -1
  275. package/dist/prometheus-framework/src/modules/organizations/components/pages/OrganizationEdit.vue.js +1 -1
  276. package/dist/prometheus-framework/src/modules/organizations/components/sections/DetailsTabSection.vue.cjs +2 -2
  277. package/dist/prometheus-framework/src/modules/organizations/components/sections/DetailsTabSection.vue.js +2 -2
  278. package/dist/prometheus-framework/src/modules/organizations/components/sections/Documents.vue.cjs +2 -2
  279. package/dist/prometheus-framework/src/modules/organizations/components/sections/Documents.vue.js +2 -2
  280. package/dist/prometheus-framework/src/modules/organizations/components/sections/Feed.vue.cjs +1 -1
  281. package/dist/prometheus-framework/src/modules/organizations/components/sections/Feed.vue.js +1 -1
  282. package/dist/prometheus-framework/src/modules/organizations/components/sections/MembersAdd.vue.cjs +1 -1
  283. package/dist/prometheus-framework/src/modules/organizations/components/sections/MembersAdd.vue.js +1 -1
  284. package/dist/prometheus-framework/src/modules/organizations/components/sections/Organizations.vue.cjs +2 -2
  285. package/dist/prometheus-framework/src/modules/organizations/components/sections/Organizations.vue.js +2 -2
  286. package/dist/prometheus-framework/src/modules/organizations/router/organizations.cjs +2 -0
  287. package/dist/prometheus-framework/src/modules/organizations/router/organizations.cjs.map +1 -1
  288. package/dist/prometheus-framework/src/modules/organizations/router/organizations.js +2 -0
  289. package/dist/prometheus-framework/src/modules/organizations/router/organizations.js.map +1 -1
  290. package/dist/prometheus-framework/src/modules/organizations/store/departments.cjs +11 -9
  291. package/dist/prometheus-framework/src/modules/organizations/store/departments.cjs.map +1 -1
  292. package/dist/prometheus-framework/src/modules/organizations/store/departments.js +6 -4
  293. package/dist/prometheus-framework/src/modules/organizations/store/departments.js.map +1 -1
  294. package/dist/prometheus-framework/src/modules/organizations/store/organizations.cjs +5 -11
  295. package/dist/prometheus-framework/src/modules/organizations/store/organizations.cjs.map +1 -1
  296. package/dist/prometheus-framework/src/modules/organizations/store/organizations.js +1 -7
  297. package/dist/prometheus-framework/src/modules/organizations/store/organizations.js.map +1 -1
  298. package/dist/prometheus-framework/src/modules/pages/pages.client.cjs +807 -801
  299. package/dist/prometheus-framework/src/modules/pages/pages.client.js +807 -801
  300. package/dist/prometheus-framework/src/modules/pages/views/components/blocks/CardPage.vue.cjs +2 -2
  301. package/dist/prometheus-framework/src/modules/pages/views/components/blocks/CardPage.vue.js +2 -2
  302. package/dist/prometheus-framework/src/modules/pages/views/components/pages/PageEdit.vue.cjs +1 -1
  303. package/dist/prometheus-framework/src/modules/pages/views/components/pages/PageEdit.vue.js +1 -1
  304. package/dist/prometheus-framework/src/modules/pages/views/router/pages.backoffice.router.cjs +5 -10
  305. package/dist/prometheus-framework/src/modules/pages/views/router/pages.backoffice.router.cjs.map +1 -1
  306. package/dist/prometheus-framework/src/modules/pages/views/router/pages.backoffice.router.js +5 -10
  307. package/dist/prometheus-framework/src/modules/pages/views/router/pages.backoffice.router.js.map +1 -1
  308. package/dist/prometheus-framework/src/modules/products/components/blocks/CardPosition.vue.cjs +1 -1
  309. package/dist/prometheus-framework/src/modules/products/components/blocks/CardPosition.vue.js +1 -1
  310. package/dist/prometheus-framework/src/modules/products/components/blocks/CardProduct.vue.cjs +12 -7
  311. package/dist/prometheus-framework/src/modules/products/components/blocks/CardProduct.vue.cjs.map +1 -1
  312. package/dist/prometheus-framework/src/modules/products/components/blocks/CardProduct.vue.js +12 -7
  313. package/dist/prometheus-framework/src/modules/products/components/blocks/CardProduct.vue.js.map +1 -1
  314. package/dist/prometheus-framework/src/modules/products/components/blocks/Images360.vue.cjs +1 -1
  315. package/dist/prometheus-framework/src/modules/products/components/blocks/Images360.vue.js +1 -1
  316. package/dist/prometheus-framework/src/modules/products/components/blocks/LeftoverPositions.vue.cjs +1 -1
  317. package/dist/prometheus-framework/src/modules/products/components/blocks/LeftoverPositions.vue.js +1 -1
  318. package/dist/prometheus-framework/src/modules/products/components/blocks/ListPositions.vue.cjs +1 -1
  319. package/dist/prometheus-framework/src/modules/products/components/blocks/ListPositions.vue.js +1 -1
  320. package/dist/prometheus-framework/src/modules/products/components/pages/CategoryEdit.vue.cjs +1 -1
  321. package/dist/prometheus-framework/src/modules/products/components/pages/CategoryEdit.vue.js +1 -1
  322. package/dist/prometheus-framework/src/modules/products/components/pages/EditLeftover.vue.cjs +1 -1
  323. package/dist/prometheus-framework/src/modules/products/components/pages/EditLeftover.vue.js +1 -1
  324. package/dist/prometheus-framework/src/modules/products/components/pages/Product.vue.cjs +1 -1
  325. package/dist/prometheus-framework/src/modules/products/components/pages/Product.vue.cjs.map +1 -1
  326. package/dist/prometheus-framework/src/modules/products/components/pages/Product.vue.js +1 -1
  327. package/dist/prometheus-framework/src/modules/products/components/pages/Product.vue.js.map +1 -1
  328. package/dist/prometheus-framework/src/modules/products/components/pages/ProductEdit.vue.cjs +1 -1
  329. package/dist/prometheus-framework/src/modules/products/components/pages/ProductEdit.vue.js +1 -1
  330. package/dist/prometheus-framework/src/modules/products/components/pages/ProductRecommmendation.vue.cjs +1 -1
  331. package/dist/prometheus-framework/src/modules/products/components/pages/ProductRecommmendation.vue.js +1 -1
  332. package/dist/prometheus-framework/src/modules/products/components/pages/Products.vue.cjs +2 -2
  333. package/dist/prometheus-framework/src/modules/products/components/pages/Products.vue.js +2 -2
  334. package/dist/prometheus-framework/src/modules/products/components/sections/EditModifications.vue.cjs +1 -1
  335. package/dist/prometheus-framework/src/modules/products/components/sections/EditModifications.vue.js +1 -1
  336. package/dist/prometheus-framework/src/modules/products/components/sections/EditProductInfo.vue.cjs +2 -2
  337. package/dist/prometheus-framework/src/modules/products/components/sections/EditProductInfo.vue.js +2 -2
  338. package/dist/prometheus-framework/src/modules/products/components/sections/FilterProducts.vue.cjs +1 -1
  339. package/dist/prometheus-framework/src/modules/products/components/sections/FilterProducts.vue.js +1 -1
  340. package/dist/prometheus-framework/src/modules/products/components/sections/PopularProducts.vue.cjs +1 -1
  341. package/dist/prometheus-framework/src/modules/products/components/sections/PopularProducts.vue.js +1 -1
  342. package/dist/prometheus-framework/src/modules/products/store/categories.cjs +7 -8
  343. package/dist/prometheus-framework/src/modules/products/store/categories.cjs.map +1 -1
  344. package/dist/prometheus-framework/src/modules/products/store/categories.js +1 -2
  345. package/dist/prometheus-framework/src/modules/products/store/categories.js.map +1 -1
  346. package/dist/prometheus-framework/src/modules/products/store/leftovers.cjs +6 -7
  347. package/dist/prometheus-framework/src/modules/products/store/leftovers.cjs.map +1 -1
  348. package/dist/prometheus-framework/src/modules/products/store/leftovers.js +1 -2
  349. package/dist/prometheus-framework/src/modules/products/store/leftovers.js.map +1 -1
  350. package/dist/prometheus-framework/src/modules/products/store/products.cjs +10 -21
  351. package/dist/prometheus-framework/src/modules/products/store/products.cjs.map +1 -1
  352. package/dist/prometheus-framework/src/modules/products/store/products.js +1 -12
  353. package/dist/prometheus-framework/src/modules/products/store/products.js.map +1 -1
  354. package/dist/prometheus-framework/src/modules/reports/components/sections/FormReport.vue.cjs.map +1 -1
  355. package/dist/prometheus-framework/src/modules/reports/components/sections/FormReport.vue.js.map +1 -1
  356. package/dist/prometheus-framework/src/modules/spots/components/blocks/CardSpot.vue.cjs +1 -1
  357. package/dist/prometheus-framework/src/modules/spots/components/blocks/CardSpot.vue.js +1 -1
  358. package/dist/prometheus-framework/src/modules/spots/components/blocks/SpotMemberModify.vue.cjs +1 -1
  359. package/dist/prometheus-framework/src/modules/spots/components/blocks/SpotMemberModify.vue.js +1 -1
  360. package/dist/prometheus-framework/src/modules/spots/components/layouts/Spots.vue.cjs +3 -3
  361. package/dist/prometheus-framework/src/modules/spots/components/layouts/Spots.vue.js +3 -3
  362. package/dist/prometheus-framework/src/modules/spots/components/pages/Spot.vue.cjs +1 -1
  363. package/dist/prometheus-framework/src/modules/spots/components/pages/Spot.vue.js +1 -1
  364. package/dist/prometheus-framework/src/modules/spots/components/pages/SpotEdit.vue.cjs +3 -3
  365. package/dist/prometheus-framework/src/modules/spots/components/pages/SpotEdit.vue.js +3 -3
  366. package/dist/prometheus-framework/src/modules/spots/store/spots.cjs +6 -9
  367. package/dist/prometheus-framework/src/modules/spots/store/spots.cjs.map +1 -1
  368. package/dist/prometheus-framework/src/modules/spots/store/spots.js +1 -4
  369. package/dist/prometheus-framework/src/modules/spots/store/spots.js.map +1 -1
  370. package/dist/prometheus-framework/src/modules/users/components/pages/Profile.vue.cjs +4 -4
  371. package/dist/prometheus-framework/src/modules/users/components/pages/Profile.vue.cjs.map +1 -1
  372. package/dist/prometheus-framework/src/modules/users/components/pages/Profile.vue.js +4 -4
  373. package/dist/prometheus-framework/src/modules/users/components/pages/Profile.vue.js.map +1 -1
  374. package/dist/prometheus-framework/src/modules/users/components/pages/ProfileEdit.vue.cjs +1 -1
  375. package/dist/prometheus-framework/src/modules/users/components/pages/ProfileEdit.vue.js +1 -1
  376. package/dist/prometheus-framework/src/modules/users/components/pages/ProfileEvents.vue.cjs +1 -1
  377. package/dist/prometheus-framework/src/modules/users/components/pages/ProfileEvents.vue.js +1 -1
  378. package/dist/prometheus-framework/src/modules/users/router/users.cjs +2 -2
  379. package/dist/prometheus-framework/src/modules/users/router/users.cjs.map +1 -1
  380. package/dist/prometheus-framework/src/modules/users/router/users.js +2 -2
  381. package/dist/prometheus-framework/src/modules/users/router/users.js.map +1 -1
  382. package/dist/prometheus-framework/src/modules/users/store/users.cjs +5 -6
  383. package/dist/prometheus-framework/src/modules/users/store/users.cjs.map +1 -1
  384. package/dist/prometheus-framework/src/modules/users/store/users.js +1 -2
  385. package/dist/prometheus-framework/src/modules/users/store/users.js.map +1 -1
  386. package/dist/prometheus-framework/src/modules/wallet/views/components/blocks/CardDeposit.vue.cjs +1 -1
  387. package/dist/prometheus-framework/src/modules/wallet/views/components/blocks/CardDeposit.vue.js +1 -1
  388. package/dist/prometheus-framework/src/modules/wallet/views/components/blocks/CryptoDeposit.vue.cjs +1 -1
  389. package/dist/prometheus-framework/src/modules/wallet/views/components/blocks/CryptoDeposit.vue.js +1 -1
  390. package/dist/prometheus-framework/src/modules/wallet/views/components/pages/Wallet.vue.cjs +2 -2
  391. package/dist/prometheus-framework/src/modules/wallet/views/components/pages/Wallet.vue.js +2 -2
  392. package/dist/prometheus-framework.cjs.js +17 -17
  393. package/dist/prometheus-framework.es.js +1790 -1790
  394. package/dist/queryProcessor-CU4A6Y4N.mjs +197 -0
  395. package/dist/queryProcessor-CcsJEUBr.js +196 -0
  396. package/dist/spots.server.js +1 -1
  397. package/dist/spots.server.mjs +1 -1
  398. package/dist/verifyAccesses-BsrJOct8.mjs +90 -0
  399. package/dist/verifyAccesses-BvLnOtBN.js +89 -0
  400. package/dist/wallet.server.js +2 -2
  401. package/dist/wallet.server.mjs +2 -2
  402. package/package.json +1 -1
  403. package/src/builder/modes/ssr.dev.js +2 -2
  404. package/src/builder/modes/ssr.prod.js +4 -4
  405. package/src/builder/ssr/ssr-render-html.js +11 -13
  406. package/src/builder/templates/page.html +37 -0
  407. package/src/builder/templates/page.js +4 -0
  408. package/src/builder/webpack/webpack.config.client.js +9 -6
  409. package/src/builder/webpack/webpack.config.ssr.js +1 -1
  410. package/src/components/Button/Button.vue +0 -1
  411. package/src/components/Feed/Feed.vue +34 -55
  412. package/src/components/FieldTags/BlockTags.vue +0 -1
  413. package/src/components/UploadImage/UploadImage.vue +2 -1
  414. package/src/modules/auth/controllers/middlewares/authJwt.js +1 -1
  415. package/src/modules/auth/controllers/middlewares/verifySignUp.js +11 -11
  416. package/src/modules/auth/controllers/routes/auth.routes.js +2 -2
  417. package/src/modules/auth/controllers/services/auth.service.js +1 -0
  418. package/src/modules/auth/views/components/pages/SignIn.vue +1 -0
  419. package/src/modules/auth/views/middlewares/auth.validation.js +17 -1
  420. package/src/modules/auth/views/middlewares/ownership.validation.js +60 -0
  421. package/src/modules/auth/views/store/auth.js +43 -39
  422. package/src/modules/auth/views/store/twofa.js +2 -5
  423. package/src/modules/auth/views/validations/inputs.validation.js +12 -6
  424. package/src/modules/community/components/blocks/CardBlogpost.vue +3 -1
  425. package/src/modules/community/components/layouts/Community.vue +7 -9
  426. package/src/modules/community/components/pages/BlogPost.vue +122 -123
  427. package/src/modules/community/components/pages/CreateBlogPost.vue +1 -1
  428. package/src/modules/community/components/sections/Comments.vue +5 -5
  429. package/src/modules/community/controllers/blog.controller.js +1 -1
  430. package/src/modules/community/models/blogpost.model.js +1 -1
  431. package/src/modules/community/router/blogposts.js +40 -33
  432. package/src/modules/community/routes/blog.routes.js +4 -0
  433. package/src/modules/community/store/blogposts.js +11 -19
  434. package/src/modules/community/store/reactions.js +1 -7
  435. package/src/modules/events/components/elements/ButtonCheck.vue +36 -66
  436. package/src/modules/events/components/pages/EditEvent.vue +76 -59
  437. package/src/modules/events/components/pages/Event.vue +2 -15
  438. package/src/modules/events/components/pages/Events.vue +2 -1
  439. package/src/modules/events/components/pages/EventsBackoffice.vue +122 -0
  440. package/src/modules/events/components/sections/HeroEvent.vue +15 -17
  441. package/src/modules/events/components/sections/SectionPreviousEvents.vue +4 -13
  442. package/src/modules/events/router/events.js +11 -4
  443. package/src/modules/events/store/events.js +2 -4
  444. package/src/modules/gallery/components/sections/BackofficeGallery.vue +24 -13
  445. package/src/modules/gallery/controllers/gallery.controller.js +30 -31
  446. package/src/modules/gallery/router/gallery.backoffice.router.js +5 -1
  447. package/src/modules/gallery/routes/gallery.routes.js +22 -4
  448. package/src/modules/globals/controllers/utils/queryProcessor.js +24 -4
  449. package/src/modules/globals/globals.client.js +2 -0
  450. package/src/modules/globals/views/classes/globals.store.js +4 -3
  451. package/src/modules/globals/views/components/blocks/Card.vue +56 -0
  452. package/src/modules/globals/views/components/blocks/CardHeader.vue +1 -3
  453. package/src/modules/globals/views/components/layouts/App.vue +1 -0
  454. package/src/modules/globals/views/components/layouts/Client.vue +0 -30
  455. package/src/modules/globals/views/store/globals.js +4 -2
  456. package/src/modules/globals/views/utils/axios-instance.js +18 -0
  457. package/src/modules/globals/views/utils/vue-app-renderer.js +87 -0
  458. package/src/modules/integrations/stripe/controllers/services/stripe.service.js +15 -30
  459. package/src/modules/landing/components/pages/Governance.vue +4 -2
  460. package/src/modules/landing/components/sections/SectionHeroToken.vue +12 -10
  461. package/src/modules/landing/components/sections/SectionsSection.vue +5 -8
  462. package/src/modules/landing/router/landing.js +2 -1
  463. package/src/modules/orders/store/orders.js +1 -3
  464. package/src/modules/organizations/components/pages/DepartmentEdit.vue +36 -0
  465. package/src/modules/organizations/components/pages/OrganizationBackoffice.vue +3 -1
  466. package/src/modules/organizations/controllers/organizations.controller.js +28 -35
  467. package/src/modules/organizations/middlewares/verifyAccesses.js +117 -0
  468. package/src/modules/organizations/models/department.model.js +3 -86
  469. package/src/modules/organizations/models/organization.model.js +6 -4
  470. package/src/modules/organizations/models/schemas/accesses.schema.js +142 -0
  471. package/src/modules/organizations/router/organizations.js +2 -0
  472. package/src/modules/organizations/store/departments.js +6 -6
  473. package/src/modules/organizations/store/organizations.js +2 -16
  474. package/src/modules/pages/views/router/pages.backoffice.router.js +5 -7
  475. package/src/modules/products/components/blocks/CardProduct.vue +2 -0
  476. package/src/modules/products/components/pages/Product.vue +1 -1
  477. package/src/modules/products/components/sections/MenuSection.vue +2 -2
  478. package/src/modules/products/controllers/products.controller.js +201 -367
  479. package/src/modules/products/routes/products.routes.js +0 -5
  480. package/src/modules/products/store/categories.js +1 -2
  481. package/src/modules/products/store/leftovers.js +1 -2
  482. package/src/modules/products/store/products.js +1 -13
  483. package/src/modules/reports/components/sections/FormReport.vue +20 -20
  484. package/src/modules/spots/store/spots.js +1 -6
  485. package/src/modules/users/components/pages/Profile.vue +1 -1
  486. package/src/modules/users/router/users.js +2 -2
  487. package/src/modules/users/store/users.js +1 -3
  488. package/src/styles/base/all.scss +0 -2
  489. package/src/styles/config.scss +6 -0
  490. package/src/modules/auth/controllers/middlewares/verifyAccesses.js +0 -114
  491. package/src/modules/users/components/pages/ProfileEvents.vue +0 -69
@@ -1 +1 @@
1
- {"version":3,"file":"inputs.validation.js","sources":["../../../../../../../src/modules/auth/views/validations/inputs.validation.js"],"sourcesContent":["// import i18n from \"@pf/src/modules/globals/views/localization/vue-i18n\";\nconst messages = {\n ru: {\n \"validation\": {\n \"length\": \"Содержимое должно быть не менее 1 символа.\",\n \"maxLength\": \"Содержимое не должно превышать {maxLength} символов.\",\n \"phone\": \"Неверный формат номера\",\n \"email\": \"Неверный формат email\",\n \"password\": {\n \"minLength\": \"Пароль должен быть больше 8 символов\",\n \"lowercase\": \"Должен быть символ в нижнем регистре\",\n \"uppercase\": \"Должен быть символ в верхнем регистре\",\n \"number\": \"Должна быть 1 цифра\",\n \"specialChar\": \"Должен быть 1 специальный символ\"\n }\n }\n },\n en: {\n \"validation\": {\n \"length\": \"Content must be at least 1 character long.\",\n \"maxLength\": \"Content should not exceed {maxLength} characters.\",\n \"phone\": \"Invalid number format\",\n \"email\": \"Invalid email format\",\n \"password\": {\n \"minLength\": \"Password must be longer than 8 characters\",\n \"lowercase\": \"Must contain a lowercase character\",\n \"uppercase\": \"Must contain an uppercase character\",\n \"number\": \"Must contain at least 1 digit\",\n \"specialChar\": \"Must contain at least 1 special character\"\n }\n }\n }\n};\n\n// i18n.global.mergeLocaleMessage('ru', messages.ru);\n// i18n.global.mergeLocaleMessage('en', messages.en);\n\nfunction validateLength(input) {\n const length = input.length;\n\n if (length < 1) {\n return {\n status: false,\n message: i18n.global.t(\"validation.length\")\n };\n }\n\n return {\n status: true,\n message: null\n };\n}\n\nfunction validatePhone(phone) {\n return {\n status: true,\n message: null\n }\n}\n\nfunction validateEmail(email) {\n const emailRegex = /^[\\w-\\.]+@([\\w-]+\\.)+[\\w-]{2,12}$/;\n\n\n if (!emailRegex.test(email)) {\n return {\n status: false,\n message: i18n.global.t(\"validation.email\")\n };\n }\n\n return {\n status: true,\n message: null\n };\n}\n\n\nfunction validatePassword(password) {\n const lowercaseRegex = /[a-z]/;\n const uppercaseRegex = /[A-Z]/;\n const numberRegex = /[0-9]/;\n const specialCharRegex = /[@$!%*?&]/;\n\n if (password.length < 8) {\n return {\n status: false,\n message: i18n.global.t(\"validation.password.minLength\")\n }\n }\n\n // if (!lowercaseRegex.test(password)) {\n // return {\n // status: false,\n // message:i18n.global.t(\"validation.password.lowercase\")\n // }\n // }\n\n // if (!uppercaseRegex.test(password)) {\n // return {\n // status: false,\n // message: i18n.global.t(\"validation.password.uppercase\")\n // }\n // }\n\n // if (!numberRegex.test(password)) {\n // return {\n // status: false,\n // message: i18n.global.t(\"validation.password.number\")\n // }\n // }\n\n // if (!specialCharRegex.test(password)) {\n // return {\n // status: false,\n // message: i18n.global.t(\"validation.password.specialChar\")\n // }\n // }\n\n return {\n status: true,\n message: null\n }\n}\n\nasync function validateInputs(input, method, variable, message) {\n if (!variable) {\n\n input.value = {\n status: false,\n message: i18n.global.t(\"validation.length\")\n }\n \n setTimeout(() => { input.value = null }, 3000);\n throw new Error(i18n.global.t(\"validation.length\"));\n }\n else {\n const InputGood = method(variable)\n\n if (!InputGood.status) {\n input.value = InputGood\n setTimeout(() => { input.value = null }, 3000);\n throw new Error(message)\n }\n }\n}\n\nexport {\n validatePhone,\n validateEmail,\n validatePassword,\n validateLength,\n validateInputs\n}"],"names":[],"mappings":"AAqDA,SAAS,cAAc,OAAO;AAC5B,SAAO;AAAA,IACL,QAAQ;AAAA,IACR,SAAS;AAAA,EACV;AACH;AAEA,SAAS,cAAc,OAAO;AAC5B,QAAM,aAAa;AAGnB,MAAI,CAAC,WAAW,KAAK,KAAK,GAAG;AAC3B,WAAO;AAAA,MACL,QAAQ;AAAA,MACR,SAAU,KAAK,OAAO,EAAE,kBAAkB;AAAA,IAChD;AAAA,EACG;AAED,SAAO;AAAA,IACL,QAAQ;AAAA,IACR,SAAS;AAAA,EACb;AACA;AAGA,SAAS,iBAAiB,UAAU;AAMlC,MAAI,SAAS,SAAS,GAAG;AACvB,WAAO;AAAA,MACL,QAAQ;AAAA,MACR,SAAU,KAAK,OAAO,EAAE,+BAA+B;AAAA,IACxD;AAAA,EACF;AA8BD,SAAO;AAAA,IACL,QAAQ;AAAA,IACR,SAAS;AAAA,EACV;AACH;AAEA,eAAe,eAAe,OAAO,QAAQ,UAAU,SAAS;AAC7D,MAAI,CAAC,UAAU;AAEd,UAAM,QAAQ;AAAA,MACZ,QAAQ;AAAA,MACR,SAAS,KAAK,OAAO,EAAE,mBAAmB;AAAA,IAC3C;AAED,eAAW,MAAM;AAAE,YAAM,QAAQ;AAAA,IAAI,GAAI,GAAI;AAC7C,UAAM,IAAI,MAAM,KAAK,OAAO,EAAE,mBAAmB,CAAC;AAAA,EACnD,OACI;AACH,UAAM,YAAY,OAAO,QAAQ;AAEjC,QAAI,CAAC,UAAU,QAAQ;AACrB,YAAM,QAAQ;AACd,iBAAW,MAAM;AAAE,cAAM,QAAQ;AAAA,MAAI,GAAI,GAAI;AAC7C,YAAM,IAAI,MAAM,OAAO;AAAA,IACxB;AAAA,EACF;AACH;"}
1
+ {"version":3,"file":"inputs.validation.js","sources":["../../../../../../../src/modules/auth/views/validations/inputs.validation.js"],"sourcesContent":["// import i18n from \"@pf/src/modules/globals/views/localization/vue-i18n\";\nconst messages = {\n ru: {\n \"validation\": {\n \"length\": \"Содержимое должно быть не менее 1 символа.\",\n \"maxLength\": \"Содержимое не должно превышать {maxLength} символов.\",\n \"phone\": \"Неверный формат номера\",\n \"email\": \"Неверный формат email\",\n \"password\": {\n \"minLength\": \"Пароль должен быть больше 8 символов\",\n \"lowercase\": \"Должен быть символ в нижнем регистре\",\n \"uppercase\": \"Должен быть символ в верхнем регистре\",\n \"number\": \"Должна быть 1 цифра\",\n \"specialChar\": \"Должен быть 1 специальный символ\"\n }\n }\n },\n en: {\n \"validation\": {\n \"length\": \"Content must be at least 1 character long.\",\n \"maxLength\": \"Content should not exceed {maxLength} characters.\",\n \"phone\": \"Invalid number format\",\n \"email\": \"Invalid email format\",\n \"password\": {\n \"minLength\": \"Password must be longer than 8 characters\",\n \"lowercase\": \"Must contain a lowercase character\",\n \"uppercase\": \"Must contain an uppercase character\",\n \"number\": \"Must contain at least 1 digit\",\n \"specialChar\": \"Must contain at least 1 special character\"\n }\n }\n }\n};\n\n// i18n.global.mergeLocaleMessage('ru', messages.ru);\n// i18n.global.mergeLocaleMessage('en', messages.en);\n\nfunction validateLength(input) {\n const length = input.length;\n\n if (length < 1) {\n return {\n status: false,\n // message: i18n.global.t(\"validation.length\")\n message: 'validation.length'\n };\n }\n\n return {\n status: true,\n message: null\n };\n}\n\nfunction validatePhone(phone) {\n return {\n status: true,\n message: null\n }\n}\n\nfunction validateEmail(email) {\n // const emailRegex = /^[\\w-\\.]+@([\\w-]+\\.)+[\\w-]{2,12}$/; Not allowing to add +1, +2, +3 and etc after email\n const emailRegex = /^[\\w-]+(\\.[\\w-]+)*(\\+[\\w-]+)?@([\\w-]+\\.)+[\\w-]{2,12}$/;\n\n\n if (!emailRegex.test(email)) {\n return {\n status: false,\n // message: i18n.global.t(\"validation.email\")\n message: 'validation.email'\n };\n }\n\n return {\n status: true,\n message: null\n };\n}\n\n\nfunction validatePassword(password) {\n const lowercaseRegex = /[a-z]/;\n const uppercaseRegex = /[A-Z]/;\n const numberRegex = /[0-9]/;\n const specialCharRegex = /[@$!%*?&]/;\n\n if (password.length < 8) {\n return {\n status: false,\n // message: i18n.global.t(\"validation.password.minLength\")\n message: 'validation.password.minLength'\n }\n }\n\n // if (!lowercaseRegex.test(password)) {\n // return {\n // status: false,\n // message:i18n.global.t(\"validation.password.lowercase\")\n // }\n // }\n\n // if (!uppercaseRegex.test(password)) {\n // return {\n // status: false,\n // message: i18n.global.t(\"validation.password.uppercase\")\n // }\n // }\n\n // if (!numberRegex.test(password)) {\n // return {\n // status: false,\n // message: i18n.global.t(\"validation.password.number\")\n // }\n // }\n\n // if (!specialCharRegex.test(password)) {\n // return {\n // status: false,\n // message: i18n.global.t(\"validation.password.specialChar\")\n // }\n // }\n\n return {\n status: true,\n message: null\n }\n}\n\nasync function validateInputs(input, method, variable, message) {\n if (!variable) {\n\n input.value = {\n status: false,\n // message: i18n.global.t(\"validation.length\")\n message: 'validation.length'\n }\n \n setTimeout(() => { input.value = null }, 3000);\n // throw new Error(i18n.global.t(\"validation.length\"));\n throw new Error('validation.length');\n }\n else {\n const InputGood = method(variable)\n\n if (!InputGood.status) {\n input.value = InputGood\n setTimeout(() => { input.value = null }, 3000);\n throw new Error(message)\n }\n }\n}\n\nexport {\n validatePhone,\n validateEmail,\n validatePassword,\n validateLength,\n validateInputs\n}"],"names":[],"mappings":"AAsDA,SAAS,cAAc,OAAO;AAC5B,SAAO;AAAA,IACL,QAAQ;AAAA,IACR,SAAS;AAAA,EACV;AACH;AAEA,SAAS,cAAc,OAAO;AAE5B,QAAM,aAAa;AAGnB,MAAI,CAAC,WAAW,KAAK,KAAK,GAAG;AAC3B,WAAO;AAAA,MACL,QAAQ;AAAA;AAAA,MAER,SAAU;AAAA,IAChB;AAAA,EACG;AAED,SAAO;AAAA,IACL,QAAQ;AAAA,IACR,SAAS;AAAA,EACb;AACA;AAGA,SAAS,iBAAiB,UAAU;AAMlC,MAAI,SAAS,SAAS,GAAG;AACvB,WAAO;AAAA,MACL,QAAQ;AAAA;AAAA,MAER,SAAU;AAAA,IACX;AAAA,EACF;AA8BD,SAAO;AAAA,IACL,QAAQ;AAAA,IACR,SAAS;AAAA,EACV;AACH;AAEA,eAAe,eAAe,OAAO,QAAQ,UAAU,SAAS;AAC7D,MAAI,CAAC,UAAU;AAEd,UAAM,QAAQ;AAAA,MACZ,QAAQ;AAAA;AAAA,MAEP,SAAS;AAAA,IACX;AAED,eAAW,MAAM;AAAE,YAAM,QAAQ;AAAA,IAAI,GAAI,GAAI;AAE7C,UAAM,IAAI,MAAM,mBAAmB;AAAA,EACpC,OACI;AACH,UAAM,YAAY,OAAO,QAAQ;AAEjC,QAAI,CAAC,UAAU,QAAQ;AACrB,YAAM,QAAQ;AACd,iBAAW,MAAM;AAAE,cAAM,QAAQ;AAAA,MAAI,GAAI,GAAI;AAC7C,YAAM,IAAI,MAAM,OAAO;AAAA,IACxB;AAAA,EACF;AACH;"}
@@ -4,7 +4,7 @@ const vue = require("vue");
4
4
  const CardHeader = require("../../../globals/views/components/blocks/CardHeader.vue.cjs");
5
5
  const FooterBlogpost = require("./FooterBlogpost.vue.cjs");
6
6
  const Text = require("../../../../components/Text/Text.vue.cjs");
7
- ;/* empty css */
7
+ ;/* empty css */
8
8
  const vueRouter = require("vue-router");
9
9
  const _hoisted_1 = { class: "pos-relative bg-light radius-big flex-column flex" };
10
10
  const _hoisted_2 = { class: "pd-t-zero pd-b-zero pd-medium" };
@@ -62,7 +62,9 @@ const _sfc_main = {
62
62
  return props.blogpost.content.find((block) => block.type === "Video");
63
63
  });
64
64
  const firstText = vue.computed(() => {
65
- return props.blogpost.content.find((block) => block.type === "Textarea");
65
+ return props.blogpost.content.find(
66
+ (block) => block.type === "Textarea" && block.class !== "h2"
67
+ );
66
68
  });
67
69
  return (_ctx, _cache) => {
68
70
  var _a;
@@ -1 +1 @@
1
- {"version":3,"file":"CardBlogpost.vue.cjs","sources":["../../../../../../../src/modules/community/components/blocks/CardBlogpost.vue"],"sourcesContent":["<template>\n\t<article \n\t\tclass=\"pos-relative bg-light radius-big flex-column flex\"\n\t>\n\t\t<CardHeader \n\t :class=\"{\n\t \t'mn-b-small pd-medium': type !== 'short',\n\t \t'flex-child-order-last flex-child mn-l-small': type === 'short',\n\t }\"\n\t :entity=\"blogpost\"\n\t :entityType=\"'blogpost'\"\n\t :user=\"user\"\n\t :owner=\"blogpost.owner\" \n \t:creator=\"blogpost.creator\"\n \t:date=\"blogpost.createdAt\"\n \t:actions=\"user && user === blogpost.creator.target._id ? [\n { to: { name: 'Edit BlogPost', params: {url: blogpost.url } }, label: 'Edit' }\n ]: null\"\n\t\t/>\n\n\t\n\t\t<section\n\t\t\tclass=\"pd-t-zero pd-b-zero pd-medium\"\n\t\t>\n\t\t\t\n\t\t\t<div v-if=\"type !== 'blogpostPage'\" class=\"cursor-pointer mn-b-thin flex-nowrap flex w-100\">\n\n\t\t\t\t<Text \n\t\t\t\t\tv-if=\"!hideTitle\"\n\t\t\t\t \t:text=\"blogpost.name || ''\" \n\t\t\t\t \t:maxLen=\"80\" \n\t\t\t\t \tclass=\"h3 d-block\"\n\t\t\t\t \t@click=\"router.push({\n\t\t\t\t\t\tname: 'BlogPost', \n\t\t\t\t\t\tparams: { \n\t\t\t\t\t\t\turl: blogpost.url \n\t\t\t\t\t\t}\n\t\t\t\t\t})\"\n\t\t\t\t/>\n\n\t\t\t\t<div \n\t\t\t\t\tv-if=\"blogpost.status === 'draft'\" \n\t\t\t\t\tclass=\"pd-micro t-white uppercase t-semi p-small flex-center flex pd-r-small pd-l-small mn-l-thin w-min bg-second radius-extra\"\n\t\t\t\t>\n\t\t\t\t\t{{blogpost.status}}\n\t\t\t\t</div>\n\t\t\t\t\n\t\t\t</div>\n\t\t\t\n\t\t\t<p \n\t\t\t\tv-if=\"firstText && firstText.content && type !== 'blogpostPage' && !hideDescription\" \n\t\t\t\tclass='mn-b-small t-transp p-big'\n\t\t\t>\n\t\t\t\t{{firstText.content.slice(0,120)}}...\n\t\t\t</p>\n\n\t\t\t<h3 \n\t\t\t\tv-if=\"type === 'blogpostPage' && !hideTitle\" \n\t\t\t\tclass=\"mn-b-small h2\"\n\t\t\t>\n\t\t\t\t{{blogpost.name}}\n\t\t\t</h3>\n\n\t\t\t<slot></slot>\n\n\t\t\t<!-- <Chips \n \tv-if=\"type !== 'short' && blogpost.tags?.length > 0\" \n \t:chips=\"blogpost.tags\"\n \t/> -->\n\n\t\t</section>\n\n\t\t\t<!-- <Image :prop=\"{content:firstImage.content}\" class=\"h-100\"/> -->\n\n\t\t<template\n\t\t\tv-if=\"firstImage && firstImage.content && type !== 'blogpostPage'\"\n\t\t>\n\t\t\t<img loading=\"lazy\" \n\t\t\t\t:src=\"(FILE_SERVER_URL || '') + firstImage.content\" \n\t\t\t\talt=\"Blog post image\" \n\t\t\t\tclass=\"mn-b-medium object-fit-cover w-100 h-min-10r h-100\"\n\t\t\t/>\n\t\t</template>\n\n\t\t<template\n\t\t\tv-if=\"!firstImage?.content && firstVideo && firstVideo.content && type !== 'blogpostPage'\"\n\t\t>\n\t\t\t<!-- <div class=\"flex-center flex\"> -->\n\t <video controls class=\"mn-b-medium object-fit-cover w-100 h-max-20r\">\n\t <source :src=\"firstVideo.content\" type=\"video/mp4\">\n\t Your browser does not support the video tag.\n\t </video>\n\t <!-- </div> -->\n\t\t</template>\n\n\t\t\n\t\t<FooterBlogpost \n\t\t\tclass=\"pd-t-zero pd-medium\" \n\t\t\t:blogpost=\"blogpost\" :user=\"user\"\n\t\t/>\n\t\n\t</article>\n\n</template>\n\n\n<script setup=\"props\">\n\timport CardHeader from '@pf/src/modules/globals/views/components/blocks/CardHeader.vue'\n\timport FooterBlogpost from '@pf/src/modules/community/components/blocks/FooterBlogpost.vue'\t\n\n\timport Image from '@pf/src/modules/constructor/components/elements/Image.vue';\n\n import Text from '@pf/src/components/Text/Text.vue'\n\timport Chips from '@pf/src/components/Chips/Chips.vue'\n\n\timport IconEdit from '@pf/src/modules/icons/navigation/IconEdit.vue'\n\n\timport { computed } from 'vue'\n\n\timport { useRouter } from 'vue-router'\n\n\tconst router = useRouter()\n\n\tconst props = defineProps({\n\t\tblogpost: {\n\t\t\ttype: Object,\n\t\t},\n\t\tuser: {\n\t\t\ttype: String,\n\t\t},\n\t\ttype: {\n\t\t\ttype: String,\n\t\t},\n\t\thideDescription: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false\n\t\t},\n\t\thideTitle: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false\n\t\t}\n\t})\n\n const firstImage = computed(() => {\n\t return props.blogpost.content.find(block => block.type === 'ImageUpload');\n\t});\n\n\tconst firstVideo = computed(() => {\n\t return props.blogpost.content.find(block => block.type === 'Video');\n\t});\n\n\tconst firstText = computed(() => {\n\t return props.blogpost.content.find(block => block.type === 'Textarea');\n\t});\n\n</script>\n\n<style lang=\"scss\">\n</style>\n\n\n"],"names":["useRouter","computed"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAyHC,UAAM,SAASA,UAAAA,UAAW;AAE1B,UAAM,QAAQ;AAoBb,UAAM,aAAaC,IAAAA,SAAS,MAAM;AACjC,aAAO,MAAM,SAAS,QAAQ,KAAK,WAAS,MAAM,SAAS,aAAa;AAAA,IAC3E,CAAE;AAED,UAAM,aAAaA,IAAAA,SAAS,MAAM;AAChC,aAAO,MAAM,SAAS,QAAQ,KAAK,WAAS,MAAM,SAAS,OAAO;AAAA,IACrE,CAAE;AAED,UAAM,YAAYA,IAAAA,SAAS,MAAM;AAC/B,aAAO,MAAM,SAAS,QAAQ,KAAK,WAAS,MAAM,SAAS,UAAU;AAAA,IACxE,CAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"CardBlogpost.vue.cjs","sources":["../../../../../../../src/modules/community/components/blocks/CardBlogpost.vue"],"sourcesContent":["<template>\n\t<article \n\t\tclass=\"pos-relative bg-light radius-big flex-column flex\"\n\t>\n\t\t<CardHeader \n\t :class=\"{\n\t \t'mn-b-small pd-medium': type !== 'short',\n\t \t'flex-child-order-last flex-child mn-l-small': type === 'short',\n\t }\"\n\t :entity=\"blogpost\"\n\t :entityType=\"'blogpost'\"\n\t :user=\"user\"\n\t :owner=\"blogpost.owner\" \n \t:creator=\"blogpost.creator\"\n \t:date=\"blogpost.createdAt\"\n \t:actions=\"user && user === blogpost.creator.target._id ? [\n { to: { name: 'Edit BlogPost', params: {url: blogpost.url } }, label: 'Edit' }\n ]: null\"\n\t\t/>\n\n\t\n\t\t<section\n\t\t\tclass=\"pd-t-zero pd-b-zero pd-medium\"\n\t\t>\n\t\t\t\n\t\t\t<div v-if=\"type !== 'blogpostPage'\" class=\"cursor-pointer mn-b-thin flex-nowrap flex w-100\">\n\n\t\t\t\t<Text \n\t\t\t\t\tv-if=\"!hideTitle\"\n\t\t\t\t \t:text=\"blogpost.name || ''\" \n\t\t\t\t \t:maxLen=\"80\" \n\t\t\t\t \tclass=\"h3 d-block\"\n\t\t\t\t \t@click=\"router.push({\n\t\t\t\t\t\tname: 'BlogPost', \n\t\t\t\t\t\tparams: { \n\t\t\t\t\t\t\turl: blogpost.url \n\t\t\t\t\t\t}\n\t\t\t\t\t})\"\n\t\t\t\t/>\n\n\t\t\t\t<div \n\t\t\t\t\tv-if=\"blogpost.status === 'draft'\" \n\t\t\t\t\tclass=\"pd-micro t-white uppercase t-semi p-small flex-center flex pd-r-small pd-l-small mn-l-thin w-min bg-second radius-extra\"\n\t\t\t\t>\n\t\t\t\t\t{{blogpost.status}}\n\t\t\t\t</div>\n\t\t\t\t\n\t\t\t</div>\n\t\t\t\n\t\t\t<p \n\t\t\t\tv-if=\"firstText && firstText.content && type !== 'blogpostPage' && !hideDescription\" \n\t\t\t\tclass='mn-b-small t-transp p-big'\n\t\t\t>\n\t\t\t\t{{firstText.content.slice(0,120)}}...\n\t\t\t</p>\n\n\t\t\t<h3 \n\t\t\t\tv-if=\"type === 'blogpostPage' && !hideTitle\" \n\t\t\t\tclass=\"mn-b-small h2\"\n\t\t\t>\n\t\t\t\t{{blogpost.name}}\n\t\t\t</h3>\n\n\t\t\t<slot></slot>\n\n\t\t\t<!-- <Chips \n \tv-if=\"type !== 'short' && blogpost.tags?.length > 0\" \n \t:chips=\"blogpost.tags\"\n \t/> -->\n\n\t\t</section>\n\n\t\t\t<!-- <Image :prop=\"{content:firstImage.content}\" class=\"h-100\"/> -->\n\n\t\t<template\n\t\t\tv-if=\"firstImage && firstImage.content && type !== 'blogpostPage'\"\n\t\t>\n\t\t\t<img loading=\"lazy\" \n\t\t\t\t:src=\"(FILE_SERVER_URL || '') + firstImage.content\" \n\t\t\t\talt=\"Blog post image\" \n\t\t\t\tclass=\"mn-b-medium object-fit-cover w-100 h-min-10r h-100\"\n\t\t\t/>\n\t\t</template>\n\n\t\t<template\n\t\t\tv-if=\"!firstImage?.content && firstVideo && firstVideo.content && type !== 'blogpostPage'\"\n\t\t>\n\t\t\t<!-- <div class=\"flex-center flex\"> -->\n\t <video controls class=\"mn-b-medium object-fit-cover w-100 h-max-20r\">\n\t <source :src=\"firstVideo.content\" type=\"video/mp4\">\n\t Your browser does not support the video tag.\n\t </video>\n\t <!-- </div> -->\n\t\t</template>\n\n\t\t\n\t\t<FooterBlogpost \n\t\t\tclass=\"pd-t-zero pd-medium\" \n\t\t\t:blogpost=\"blogpost\" :user=\"user\"\n\t\t/>\n\t\n\t</article>\n\n</template>\n\n\n<script setup=\"props\">\n\timport CardHeader from '@pf/src/modules/globals/views/components/blocks/CardHeader.vue'\n\timport FooterBlogpost from '@pf/src/modules/community/components/blocks/FooterBlogpost.vue'\t\n\n\timport Image from '@pf/src/modules/constructor/components/elements/Image.vue';\n\n import Text from '@pf/src/components/Text/Text.vue'\n\timport Chips from '@pf/src/components/Chips/Chips.vue'\n\n\timport IconEdit from '@pf/src/modules/icons/navigation/IconEdit.vue'\n\n\timport { computed } from 'vue'\n\n\timport { useRouter } from 'vue-router'\n\n\tconst router = useRouter()\n\n\tconst props = defineProps({\n\t\tblogpost: {\n\t\t\ttype: Object,\n\t\t},\n\t\tuser: {\n\t\t\ttype: String,\n\t\t},\n\t\ttype: {\n\t\t\ttype: String,\n\t\t},\n\t\thideDescription: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false\n\t\t},\n\t\thideTitle: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false\n\t\t}\n\t})\n\n const firstImage = computed(() => {\n\t return props.blogpost.content.find(block => block.type === 'ImageUpload');\n\t});\n\n\tconst firstVideo = computed(() => {\n\t return props.blogpost.content.find(block => block.type === 'Video');\n\t});\n\n\tconst firstText = computed(() => {\n\t return props.blogpost.content.find(block => \n\t block.type === 'Textarea' && block.class !== 'h2'\n\t );\n\t});\n\n</script>\n\n<style lang=\"scss\">\n</style>\n\n\n"],"names":["useRouter","computed"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAyHC,UAAM,SAASA,UAAAA,UAAW;AAE1B,UAAM,QAAQ;AAoBb,UAAM,aAAaC,IAAAA,SAAS,MAAM;AACjC,aAAO,MAAM,SAAS,QAAQ,KAAK,WAAS,MAAM,SAAS,aAAa;AAAA,IAC3E,CAAE;AAED,UAAM,aAAaA,IAAAA,SAAS,MAAM;AAChC,aAAO,MAAM,SAAS,QAAQ,KAAK,WAAS,MAAM,SAAS,OAAO;AAAA,IACrE,CAAE;AAED,UAAM,YAAYA,IAAAA,SAAS,MAAM;AAC/B,aAAO,MAAM,SAAS,QAAQ;AAAA,QAAK,WACjC,MAAM,SAAS,cAAc,MAAM,UAAU;AAAA,MAClD;AAAA,IACA,CAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -2,7 +2,7 @@ import { computed, openBlock, createElementBlock, createVNode, normalizeClass, c
2
2
  import _sfc_main$1 from "../../../globals/views/components/blocks/CardHeader.vue.js";
3
3
  import _sfc_main$3 from "./FooterBlogpost.vue.js";
4
4
  import _sfc_main$2 from "../../../../components/Text/Text.vue.js";
5
- /* empty css */
5
+ /* empty css */
6
6
  import { useRouter } from "vue-router";
7
7
  const _hoisted_1 = { class: "pos-relative bg-light radius-big flex-column flex" };
8
8
  const _hoisted_2 = { class: "pd-t-zero pd-b-zero pd-medium" };
@@ -60,7 +60,9 @@ const _sfc_main = {
60
60
  return props.blogpost.content.find((block) => block.type === "Video");
61
61
  });
62
62
  const firstText = computed(() => {
63
- return props.blogpost.content.find((block) => block.type === "Textarea");
63
+ return props.blogpost.content.find(
64
+ (block) => block.type === "Textarea" && block.class !== "h2"
65
+ );
64
66
  });
65
67
  return (_ctx, _cache) => {
66
68
  var _a;
@@ -1 +1 @@
1
- {"version":3,"file":"CardBlogpost.vue.js","sources":["../../../../../../../src/modules/community/components/blocks/CardBlogpost.vue"],"sourcesContent":["<template>\n\t<article \n\t\tclass=\"pos-relative bg-light radius-big flex-column flex\"\n\t>\n\t\t<CardHeader \n\t :class=\"{\n\t \t'mn-b-small pd-medium': type !== 'short',\n\t \t'flex-child-order-last flex-child mn-l-small': type === 'short',\n\t }\"\n\t :entity=\"blogpost\"\n\t :entityType=\"'blogpost'\"\n\t :user=\"user\"\n\t :owner=\"blogpost.owner\" \n \t:creator=\"blogpost.creator\"\n \t:date=\"blogpost.createdAt\"\n \t:actions=\"user && user === blogpost.creator.target._id ? [\n { to: { name: 'Edit BlogPost', params: {url: blogpost.url } }, label: 'Edit' }\n ]: null\"\n\t\t/>\n\n\t\n\t\t<section\n\t\t\tclass=\"pd-t-zero pd-b-zero pd-medium\"\n\t\t>\n\t\t\t\n\t\t\t<div v-if=\"type !== 'blogpostPage'\" class=\"cursor-pointer mn-b-thin flex-nowrap flex w-100\">\n\n\t\t\t\t<Text \n\t\t\t\t\tv-if=\"!hideTitle\"\n\t\t\t\t \t:text=\"blogpost.name || ''\" \n\t\t\t\t \t:maxLen=\"80\" \n\t\t\t\t \tclass=\"h3 d-block\"\n\t\t\t\t \t@click=\"router.push({\n\t\t\t\t\t\tname: 'BlogPost', \n\t\t\t\t\t\tparams: { \n\t\t\t\t\t\t\turl: blogpost.url \n\t\t\t\t\t\t}\n\t\t\t\t\t})\"\n\t\t\t\t/>\n\n\t\t\t\t<div \n\t\t\t\t\tv-if=\"blogpost.status === 'draft'\" \n\t\t\t\t\tclass=\"pd-micro t-white uppercase t-semi p-small flex-center flex pd-r-small pd-l-small mn-l-thin w-min bg-second radius-extra\"\n\t\t\t\t>\n\t\t\t\t\t{{blogpost.status}}\n\t\t\t\t</div>\n\t\t\t\t\n\t\t\t</div>\n\t\t\t\n\t\t\t<p \n\t\t\t\tv-if=\"firstText && firstText.content && type !== 'blogpostPage' && !hideDescription\" \n\t\t\t\tclass='mn-b-small t-transp p-big'\n\t\t\t>\n\t\t\t\t{{firstText.content.slice(0,120)}}...\n\t\t\t</p>\n\n\t\t\t<h3 \n\t\t\t\tv-if=\"type === 'blogpostPage' && !hideTitle\" \n\t\t\t\tclass=\"mn-b-small h2\"\n\t\t\t>\n\t\t\t\t{{blogpost.name}}\n\t\t\t</h3>\n\n\t\t\t<slot></slot>\n\n\t\t\t<!-- <Chips \n \tv-if=\"type !== 'short' && blogpost.tags?.length > 0\" \n \t:chips=\"blogpost.tags\"\n \t/> -->\n\n\t\t</section>\n\n\t\t\t<!-- <Image :prop=\"{content:firstImage.content}\" class=\"h-100\"/> -->\n\n\t\t<template\n\t\t\tv-if=\"firstImage && firstImage.content && type !== 'blogpostPage'\"\n\t\t>\n\t\t\t<img loading=\"lazy\" \n\t\t\t\t:src=\"(FILE_SERVER_URL || '') + firstImage.content\" \n\t\t\t\talt=\"Blog post image\" \n\t\t\t\tclass=\"mn-b-medium object-fit-cover w-100 h-min-10r h-100\"\n\t\t\t/>\n\t\t</template>\n\n\t\t<template\n\t\t\tv-if=\"!firstImage?.content && firstVideo && firstVideo.content && type !== 'blogpostPage'\"\n\t\t>\n\t\t\t<!-- <div class=\"flex-center flex\"> -->\n\t <video controls class=\"mn-b-medium object-fit-cover w-100 h-max-20r\">\n\t <source :src=\"firstVideo.content\" type=\"video/mp4\">\n\t Your browser does not support the video tag.\n\t </video>\n\t <!-- </div> -->\n\t\t</template>\n\n\t\t\n\t\t<FooterBlogpost \n\t\t\tclass=\"pd-t-zero pd-medium\" \n\t\t\t:blogpost=\"blogpost\" :user=\"user\"\n\t\t/>\n\t\n\t</article>\n\n</template>\n\n\n<script setup=\"props\">\n\timport CardHeader from '@pf/src/modules/globals/views/components/blocks/CardHeader.vue'\n\timport FooterBlogpost from '@pf/src/modules/community/components/blocks/FooterBlogpost.vue'\t\n\n\timport Image from '@pf/src/modules/constructor/components/elements/Image.vue';\n\n import Text from '@pf/src/components/Text/Text.vue'\n\timport Chips from '@pf/src/components/Chips/Chips.vue'\n\n\timport IconEdit from '@pf/src/modules/icons/navigation/IconEdit.vue'\n\n\timport { computed } from 'vue'\n\n\timport { useRouter } from 'vue-router'\n\n\tconst router = useRouter()\n\n\tconst props = defineProps({\n\t\tblogpost: {\n\t\t\ttype: Object,\n\t\t},\n\t\tuser: {\n\t\t\ttype: String,\n\t\t},\n\t\ttype: {\n\t\t\ttype: String,\n\t\t},\n\t\thideDescription: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false\n\t\t},\n\t\thideTitle: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false\n\t\t}\n\t})\n\n const firstImage = computed(() => {\n\t return props.blogpost.content.find(block => block.type === 'ImageUpload');\n\t});\n\n\tconst firstVideo = computed(() => {\n\t return props.blogpost.content.find(block => block.type === 'Video');\n\t});\n\n\tconst firstText = computed(() => {\n\t return props.blogpost.content.find(block => block.type === 'Textarea');\n\t});\n\n</script>\n\n<style lang=\"scss\">\n</style>\n\n\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAyHC,UAAM,SAAS,UAAW;AAE1B,UAAM,QAAQ;AAoBb,UAAM,aAAa,SAAS,MAAM;AACjC,aAAO,MAAM,SAAS,QAAQ,KAAK,WAAS,MAAM,SAAS,aAAa;AAAA,IAC3E,CAAE;AAED,UAAM,aAAa,SAAS,MAAM;AAChC,aAAO,MAAM,SAAS,QAAQ,KAAK,WAAS,MAAM,SAAS,OAAO;AAAA,IACrE,CAAE;AAED,UAAM,YAAY,SAAS,MAAM;AAC/B,aAAO,MAAM,SAAS,QAAQ,KAAK,WAAS,MAAM,SAAS,UAAU;AAAA,IACxE,CAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"CardBlogpost.vue.js","sources":["../../../../../../../src/modules/community/components/blocks/CardBlogpost.vue"],"sourcesContent":["<template>\n\t<article \n\t\tclass=\"pos-relative bg-light radius-big flex-column flex\"\n\t>\n\t\t<CardHeader \n\t :class=\"{\n\t \t'mn-b-small pd-medium': type !== 'short',\n\t \t'flex-child-order-last flex-child mn-l-small': type === 'short',\n\t }\"\n\t :entity=\"blogpost\"\n\t :entityType=\"'blogpost'\"\n\t :user=\"user\"\n\t :owner=\"blogpost.owner\" \n \t:creator=\"blogpost.creator\"\n \t:date=\"blogpost.createdAt\"\n \t:actions=\"user && user === blogpost.creator.target._id ? [\n { to: { name: 'Edit BlogPost', params: {url: blogpost.url } }, label: 'Edit' }\n ]: null\"\n\t\t/>\n\n\t\n\t\t<section\n\t\t\tclass=\"pd-t-zero pd-b-zero pd-medium\"\n\t\t>\n\t\t\t\n\t\t\t<div v-if=\"type !== 'blogpostPage'\" class=\"cursor-pointer mn-b-thin flex-nowrap flex w-100\">\n\n\t\t\t\t<Text \n\t\t\t\t\tv-if=\"!hideTitle\"\n\t\t\t\t \t:text=\"blogpost.name || ''\" \n\t\t\t\t \t:maxLen=\"80\" \n\t\t\t\t \tclass=\"h3 d-block\"\n\t\t\t\t \t@click=\"router.push({\n\t\t\t\t\t\tname: 'BlogPost', \n\t\t\t\t\t\tparams: { \n\t\t\t\t\t\t\turl: blogpost.url \n\t\t\t\t\t\t}\n\t\t\t\t\t})\"\n\t\t\t\t/>\n\n\t\t\t\t<div \n\t\t\t\t\tv-if=\"blogpost.status === 'draft'\" \n\t\t\t\t\tclass=\"pd-micro t-white uppercase t-semi p-small flex-center flex pd-r-small pd-l-small mn-l-thin w-min bg-second radius-extra\"\n\t\t\t\t>\n\t\t\t\t\t{{blogpost.status}}\n\t\t\t\t</div>\n\t\t\t\t\n\t\t\t</div>\n\t\t\t\n\t\t\t<p \n\t\t\t\tv-if=\"firstText && firstText.content && type !== 'blogpostPage' && !hideDescription\" \n\t\t\t\tclass='mn-b-small t-transp p-big'\n\t\t\t>\n\t\t\t\t{{firstText.content.slice(0,120)}}...\n\t\t\t</p>\n\n\t\t\t<h3 \n\t\t\t\tv-if=\"type === 'blogpostPage' && !hideTitle\" \n\t\t\t\tclass=\"mn-b-small h2\"\n\t\t\t>\n\t\t\t\t{{blogpost.name}}\n\t\t\t</h3>\n\n\t\t\t<slot></slot>\n\n\t\t\t<!-- <Chips \n \tv-if=\"type !== 'short' && blogpost.tags?.length > 0\" \n \t:chips=\"blogpost.tags\"\n \t/> -->\n\n\t\t</section>\n\n\t\t\t<!-- <Image :prop=\"{content:firstImage.content}\" class=\"h-100\"/> -->\n\n\t\t<template\n\t\t\tv-if=\"firstImage && firstImage.content && type !== 'blogpostPage'\"\n\t\t>\n\t\t\t<img loading=\"lazy\" \n\t\t\t\t:src=\"(FILE_SERVER_URL || '') + firstImage.content\" \n\t\t\t\talt=\"Blog post image\" \n\t\t\t\tclass=\"mn-b-medium object-fit-cover w-100 h-min-10r h-100\"\n\t\t\t/>\n\t\t</template>\n\n\t\t<template\n\t\t\tv-if=\"!firstImage?.content && firstVideo && firstVideo.content && type !== 'blogpostPage'\"\n\t\t>\n\t\t\t<!-- <div class=\"flex-center flex\"> -->\n\t <video controls class=\"mn-b-medium object-fit-cover w-100 h-max-20r\">\n\t <source :src=\"firstVideo.content\" type=\"video/mp4\">\n\t Your browser does not support the video tag.\n\t </video>\n\t <!-- </div> -->\n\t\t</template>\n\n\t\t\n\t\t<FooterBlogpost \n\t\t\tclass=\"pd-t-zero pd-medium\" \n\t\t\t:blogpost=\"blogpost\" :user=\"user\"\n\t\t/>\n\t\n\t</article>\n\n</template>\n\n\n<script setup=\"props\">\n\timport CardHeader from '@pf/src/modules/globals/views/components/blocks/CardHeader.vue'\n\timport FooterBlogpost from '@pf/src/modules/community/components/blocks/FooterBlogpost.vue'\t\n\n\timport Image from '@pf/src/modules/constructor/components/elements/Image.vue';\n\n import Text from '@pf/src/components/Text/Text.vue'\n\timport Chips from '@pf/src/components/Chips/Chips.vue'\n\n\timport IconEdit from '@pf/src/modules/icons/navigation/IconEdit.vue'\n\n\timport { computed } from 'vue'\n\n\timport { useRouter } from 'vue-router'\n\n\tconst router = useRouter()\n\n\tconst props = defineProps({\n\t\tblogpost: {\n\t\t\ttype: Object,\n\t\t},\n\t\tuser: {\n\t\t\ttype: String,\n\t\t},\n\t\ttype: {\n\t\t\ttype: String,\n\t\t},\n\t\thideDescription: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false\n\t\t},\n\t\thideTitle: {\n\t\t\ttype: Boolean,\n\t\t\tdefault: false\n\t\t}\n\t})\n\n const firstImage = computed(() => {\n\t return props.blogpost.content.find(block => block.type === 'ImageUpload');\n\t});\n\n\tconst firstVideo = computed(() => {\n\t return props.blogpost.content.find(block => block.type === 'Video');\n\t});\n\n\tconst firstText = computed(() => {\n\t return props.blogpost.content.find(block => \n\t block.type === 'Textarea' && block.class !== 'h2'\n\t );\n\t});\n\n</script>\n\n<style lang=\"scss\">\n</style>\n\n\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAyHC,UAAM,SAAS,UAAW;AAE1B,UAAM,QAAQ;AAoBb,UAAM,aAAa,SAAS,MAAM;AACjC,aAAO,MAAM,SAAS,QAAQ,KAAK,WAAS,MAAM,SAAS,aAAa;AAAA,IAC3E,CAAE;AAED,UAAM,aAAa,SAAS,MAAM;AAChC,aAAO,MAAM,SAAS,QAAQ,KAAK,WAAS,MAAM,SAAS,OAAO;AAAA,IACrE,CAAE;AAED,UAAM,YAAY,SAAS,MAAM;AAC/B,aAAO,MAAM,SAAS,QAAQ;AAAA,QAAK,WACjC,MAAM,SAAS,cAAc,MAAM,UAAU;AAAA,MAClD;AAAA,IACA,CAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -15,11 +15,14 @@ const organizations = require("../../../organizations/store/organizations.cjs");
15
15
  const memberships = require("../../../organizations/store/memberships.cjs");
16
16
  const _hoisted_1 = {
17
17
  style: { "grid-template-columns": "2fr 4fr 2fr" },
18
- class: "cols-3 gap-thin pd-thin"
18
+ class: "cols-3 gap-thin pd-t-zero pd-thin"
19
19
  };
20
- const _hoisted_2 = { class: "align-self-start pos-sticky pos-t-0 w-100 bg-light radius-big pd-medium p-medium gap-thin flex-column flex-nowrap flex" };
20
+ const _hoisted_2 = { class: "align-self-start pos-sticky pos-t-0 w-100 bg-light radius-big pd-medium p-medium gap-thin flex-column mobile:flex-row flex-nowrap flex z-index-2 o-scroll t-nowrap scroll-hide" };
21
21
  const _hoisted_3 = { class: "pos-relative" };
22
- const _hoisted_4 = { class: "bg-main t-black radius-big pd-medium pos-relative mn-b-thin flex-v-center t-left flex-nowrap flex" };
22
+ const _hoisted_4 = {
23
+ key: 0,
24
+ class: "bg-light t-black radius-big pd-medium pos-relative mn-b-thin flex-v-center t-left flex-nowrap flex"
25
+ };
23
26
  const _hoisted_5 = { class: "pos-relative flex-v-center flex-nowrap flex" };
24
27
  const _hoisted_6 = /* @__PURE__ */ vue.createElementVNode("span", { class: "mn-r-thin" }, "Topics for ", -1);
25
28
  const _hoisted_7 = { class: "align-self-start bg-light radius-big pd-medium" };
@@ -81,20 +84,21 @@ const _sfc_main = {
81
84
  vue.createVNode(IconFollowing.default, { class: "i-medium mn-r-thin t-transp" }),
82
85
  vue.createTextVNode(" Following ")
83
86
  ], 2)) : vue.createCommentVNode("", true),
84
- vue.createVNode(_component_router_link, {
87
+ auth.state.user._id ? (vue.openBlock(), vue.createBlock(_component_router_link, {
88
+ key: 1,
85
89
  to: {
86
90
  name: "Create BlogPost"
87
91
  },
88
- class: "button t-medium mn-t-small bg-main w-100"
92
+ class: "button t-medium bg-main w-100"
89
93
  }, {
90
94
  default: vue.withCtx(() => [
91
95
  vue.createTextVNode(" Create Post ")
92
96
  ]),
93
97
  _: 1
94
- })
98
+ })) : vue.createCommentVNode("", true)
95
99
  ]),
96
100
  vue.createElementVNode("section", _hoisted_3, [
97
- vue.createElementVNode("header", _hoisted_4, [
101
+ !vue.unref(route).params.url ? (vue.openBlock(), vue.createElementBlock("header", _hoisted_4, [
98
102
  vue.createElementVNode("h3", _hoisted_5, [
99
103
  _hoisted_6,
100
104
  vue.createVNode(Select.default, {
@@ -102,10 +106,10 @@ const _sfc_main = {
102
106
  select: blogposts.state.filter.period,
103
107
  "onUpdate:select": _cache[4] || (_cache[4] = ($event) => blogposts.state.filter.period = $event),
104
108
  placeholder: "all time",
105
- class: "t-semi pos-relative w-max bg-main t-black pd-thin radius-medium h3 t-center br-solid br-2px br-black-transp-10"
109
+ class: "t-semi pos-relative w-max bg-main t-black pd-thin radius-medium h3 t-center"
106
110
  }, null, 8, ["select"])
107
111
  ])
108
- ]),
112
+ ])) : vue.createCommentVNode("", true),
109
113
  vue.createVNode(_component_router_view, null, {
110
114
  default: vue.withCtx(({ Component, route: route2 }) => [
111
115
  vue.createVNode(vue.Transition, {
@@ -1 +1 @@
1
- {"version":3,"file":"Community.vue.cjs","sources":["../../../../../../../src/modules/community/components/layouts/Community.vue"],"sourcesContent":["<template>\n\t<div style=\"grid-template-columns: 2fr 4fr 2fr;\" class=\"cols-3 gap-thin pd-thin\">\n\n\t\t<ul class=\"align-self-start pos-sticky pos-t-0 w-100 bg-light radius-big pd-medium p-medium gap-thin flex-column flex-nowrap flex\">\n\t\t\t<li \t\n\t\t\t\t:class=\"{'t-black bg-white': route.params.category === 'featured' }\" \t\t\t\t\t\n\t\t\t\t@click=\"() => { blog.state.sort.param = 'createdAt'; router.push({name: 'Blog', params: { category: 'featured' } })}\" \n\t\t\t\tclass=\"cursor-pointer flex-v-center flex t-medium pd-thin radius-extra\"\n\t\t\t>\n\t\t\t\t<IconFeatured class=\"i-medium mn-r-thin t-transp\"/>\n\t\t\t\tFeatured\n\t\t\t</li>\n\t\t\t<li \t\n\t\t\t\t:class=\"{'t-black bg-white': route.params.category === 'popular' }\"\t\t\t\t\t \t\t\t\t\n\t\t\t\t@click=\"() => { blog.state.sort.param = 'views'; router.push({name: 'Blog', params: { category: 'popular' } }) }\" \n\t\t\t\tclass=\"cursor-pointer t-medium flex-v-center flex pd-thin radius-extra\"\n\t\t\t>\t\n\t\t\t\t<IconPopular class=\"i-medium mn-r-thin t-transp\"/>\n\t\t\t\tPopular\n\t\t\t</li>\n\t\t\t<li \t\n\t\t\t\t:class=\"{'t-black bg-white': route.params.category === 'new'}\" \t\t\t\t\t\n\t\t\t\t@click=\"() => { blog.state.sort.param = 'createdAt'; router.push({name: 'Blog', params: { category: 'new' } })}\" \n\t\t\t\tclass=\"cursor-pointer t-medium flex-v-center flex pd-thin radius-extra\"\n\t\t\t>\n\t\t\t\t<IconRecent class=\"i-medium mn-r-thin t-transp\"/>\n\t\t\t\tRecent\n\t\t\t</li>\n\t\t\t<li \t\n\t\t\t\tv-if=\"auth.state.user._id\"\n\t\t\t\t:class=\"{'t-black bg-white': route.params.category === 'following'}\" \t\t\n\t\t\t\t@click=\"() => { blog.state.sort.param = 'createdAt'; router.push({name: 'Blog', params: { category: 'following' } })}\" \n\t\t\t\tclass=\"cursor-pointer t-medium flex-v-center flex pd-thin radius-extra\"\n\t\t\t>\n\t\t\t\t<IconFollowing class=\"i-medium mn-r-thin t-transp\"/>\n\t\t\t\tFollowing\n\t\t\t</li>\n\n\t\t\t<router-link \n\t\t\t\t:to=\"{\n\t\t\t\t\tname: 'Create BlogPost'\n\t\t\t\t}\" \n\t\t\t\tclass=\"button t-medium mn-t-small bg-main w-100\"\n\t\t\t>\n\t\t\t\tCreate Post\n\t\t\t</router-link>\n\t\t</ul>\n\n\t\t<section class=\"pos-relative\">\n\n\t\t\t<header class=\"bg-main t-black radius-big pd-medium pos-relative mn-b-thin flex-v-center t-left flex-nowrap flex\">\n\t \t<h3 class=\"pos-relative flex-v-center flex-nowrap flex\">\n\t \t\t<span class=\"mn-r-thin\">Topics for </span>\n\n\t \t\t<Select \n\t\t :options=\"['today','week','month','year','all time']\"\n\t\t v-model:select=\"blog.state.filter.period\" \n\t\t placeholder=\"all time\"\n\t\t class=\"\n\t\t \tt-semi\n\t\t \tpos-relative \n\t\t \tw-max\n\t\t \tbg-main t-black\n\t\t \tpd-thin\n\t\t \tradius-medium\n\t\t h3\n\t\t \tt-center\n\t\t \tbr-solid\n\t\t \tbr-2px\n\t\t \tbr-black-transp-10\n\t\t \"\n\t\t />\n\t \t</h3>\n\t\t\t</header>\n\n\t\t\t<router-view v-slot=\"{ Component, route }\">\n\t\t\t\t<transition name=\"scaleIn\" mode=\"out-in\">\n\t\t\t\t\t<component ref=\"page\" :key=\"route.query\" :is=\"Component\" />\n\t\t\t\t</transition>\n\t\t\t</router-view>\n\n\t\t</section>\n\n\t\t<div class=\"align-self-start bg-light radius-big pd-medium\">\n\t\t\t<div class=\"gap-thin flex-nowrap flex\">\n\t\t\t\t<p class=\"t-medium mn-b-small\">Popular Communities</p>\n\t\t\t\t\n\t\t\t\t<router-link \n\t\t\t\t\tv-if=\"auth.state.user._id\"\n\t\t\t\t\t:to=\"{\n\t\t\t\t\t\tname: 'Create Organization'\n\t\t\t\t\t}\"\n\t\t\t\t\tclass=\"t-medium cursor-pointer hover-scale-1 radius-extra flex-center flex i-medium bg-main\"\n\t\t\t\t>\n\t\t\t\t\t+\n\t\t\t\t</router-link>\n\t\t\t</div>\n\n\n\t\t\t<transition name=\"slide-fade\">\n\t\t\t\t<Feed\n\t\t :states=\"{\n\t\t empty: {\n\t\t title: 'No Organization Found',\n\t\t description: 'Currently, there are no organization available.'\n\t\t }\n\t\t }\"\n\t\t :store=\"{\n\t\t read: (options) => organizations.actions.read(options),\n\t\t state: organizations.state\n\t\t }\"\n\t\t :options=\"{\n\t\t \tuser: auth.state.user._id,\n\t\t\t\t\t\t\tsort: 'numberOfMemberships',\n\t\t\t\t\t\t\tcontain: ['blogposts'],\n\t\t\t\t\t\t\tlimit: 10\n\t\t }\"\n\t\t v-slot=\"{ \n\t\t items \n\t\t }\"\n\t\t >\n\t\t \t<CardOrganization \n\t \t\t\tv-for=\"organization in items\"\n\t \t:key=\"organization._id\" \n\t\t \t:organization=\"organization\"\n\t\t \t:user=\"auth.state.user\"\n\t\t \t:showProducts=\"false\"\n\t\t \t:showRating=\"false\"\n\t\t \t:showFeatured=\"false\"\n\t\t \t:showFollowers=\"false\"\n\t\t\t\t\t\t@updateMembership=\"handleMembershipUpdate\"\n\t\t\t\t\t\tclass=\"mn-b-thin w-100 pd-0 bg-white radius-big o-hidden\"\n\t\t\t />\n\t\t </Feed>\n\t\t\t</transition>\n\t\t</div>\n</div>\n</template>\n\n<script setup=\"props\">\n\timport { computed,onMounted, toRefs,ref } from 'vue'\n import { useRoute,useRouter } from 'vue-router'\n\n\timport Select from '@pf/src/components/Select/Select.vue'\n\timport Feed from '@pf/src/components/Feed/Feed.vue'\n\timport CardOrganization from '@pf/src/modules/organizations/components/blocks/CardOrganization.vue'\n\n\timport IconFeatured from '@pf/src/modules/icons/entities/IconFeatured.vue'\n\timport IconPopular from '@pf/src/modules/icons/entities/IconPopular.vue'\n\timport IconRecent from '@pf/src/modules/icons/entities/IconRecent.vue'\n\timport IconFollowing from '@pf/src/modules/icons/entities/IconFollowing.vue'\n\n \t// Import state\n\timport * as blog from '@pf/src/modules/community/store/blogposts.js';\n\timport * as auth from '@pf/src/modules/auth/views/store/auth'\n\timport * as organizations from '@pf/src/modules/organizations/store/organizations'\n\timport * as memberships from '@pf/src/modules/organizations/store/memberships'\n\n\t// State\n\tconst route = useRoute();\n\tconst router = useRouter();\n\n\tif (route.params.category === 'popular') blog.state.sort.param = 'views'; \n\tif (route.params.category === 'new') blog.state.sort.param = 'createdAt'; \n\n\n\tconst handleMembershipUpdate = ({ membership, status, target }, statusName, statusNumber) => {\n\t memberships.mutations.handleMembershipUpdate(organizations.state.current, membership, status, target, statusName, statusNumber)\n\t};\n\n</script>\n\n<style lang=\"scss\">\n\n</style>\n"],"names":["useRoute","useRouter","blog.state","memberships.mutations","organizations.state"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA+JC,UAAM,QAAQA,UAAAA;AACd,UAAM,SAASC,UAAAA;AAEf,QAAI,MAAM,OAAO,aAAa,UAAWC,WAAAA,MAAW,KAAK,QAAQ;AACjE,QAAI,MAAM,OAAO,aAAa,MAAOA,WAAAA,MAAW,KAAK,QAAQ;AAG7D,UAAM,yBAAyB,CAAC,EAAE,YAAY,QAAQ,OAAQ,GAAE,YAAY,iBAAiB;AAC3FC,4BAAsB,uBAAuBC,cAAAA,MAAoB,SAAS,YAAY,QAAQ,QAAQ,YAAY,YAAY;AAAA,IACjI;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"Community.vue.cjs","sources":["../../../../../../../src/modules/community/components/layouts/Community.vue"],"sourcesContent":["<template>\n\t<div style=\"grid-template-columns: 2fr 4fr 2fr;\" class=\"cols-3 gap-thin pd-t-zero pd-thin\">\n\n\t\t<ul class=\"align-self-start pos-sticky pos-t-0 w-100 bg-light radius-big pd-medium p-medium gap-thin flex-column mobile:flex-row flex-nowrap flex z-index-2 o-scroll t-nowrap scroll-hide\">\n\t\t\t<li \t\n\t\t\t\t:class=\"{'t-black bg-white': route.params.category === 'featured' }\" \t\t\t\t\t\n\t\t\t\t@click=\"() => { blog.state.sort.param = 'createdAt'; router.push({name: 'Blog', params: { category: 'featured' } })}\" \n\t\t\t\tclass=\"cursor-pointer flex-v-center flex t-medium pd-thin radius-extra\"\n\t\t\t>\n\t\t\t\t<IconFeatured class=\"i-medium mn-r-thin t-transp\"/>\n\t\t\t\tFeatured\n\t\t\t</li>\n\t\t\t<li \t\n\t\t\t\t:class=\"{'t-black bg-white': route.params.category === 'popular' }\"\t\t\t\t\t \t\t\t\t\n\t\t\t\t@click=\"() => { blog.state.sort.param = 'views'; router.push({name: 'Blog', params: { category: 'popular' } }) }\" \n\t\t\t\tclass=\"cursor-pointer t-medium flex-v-center flex pd-thin radius-extra\"\n\t\t\t>\t\n\t\t\t\t<IconPopular class=\"i-medium mn-r-thin t-transp\"/>\n\t\t\t\tPopular\n\t\t\t</li>\n\t\t\t<li \t\n\t\t\t\t:class=\"{'t-black bg-white': route.params.category === 'new'}\" \t\t\t\t\t\n\t\t\t\t@click=\"() => { blog.state.sort.param = 'createdAt'; router.push({name: 'Blog', params: { category: 'new' } })}\" \n\t\t\t\tclass=\"cursor-pointer t-medium flex-v-center flex pd-thin radius-extra\"\n\t\t\t>\n\t\t\t\t<IconRecent class=\"i-medium mn-r-thin t-transp\"/>\n\t\t\t\tRecent\n\t\t\t</li>\n\t\t\t<li \t\n\t\t\t\tv-if=\"auth.state.user._id\"\n\t\t\t\t:class=\"{'t-black bg-white': route.params.category === 'following'}\" \t\t\n\t\t\t\t@click=\"() => { blog.state.sort.param = 'createdAt'; router.push({name: 'Blog', params: { category: 'following' } })}\" \n\t\t\t\tclass=\"cursor-pointer t-medium flex-v-center flex pd-thin radius-extra\"\n\t\t\t>\n\t\t\t\t<IconFollowing class=\"i-medium mn-r-thin t-transp\"/>\n\t\t\t\tFollowing\n\t\t\t</li>\n\n\t\t\t<router-link \n\t\t\t\tv-if=\"auth.state.user._id\"\n\t\t\t\t:to=\"{\n\t\t\t\t\tname: 'Create BlogPost'\n\t\t\t\t}\" \n\t\t\t\tclass=\"button t-medium bg-main w-100\"\n\t\t\t>\n\t\t\t\tCreate Post\n\t\t\t</router-link>\n\t\t</ul>\n\n\t\t<section class=\"pos-relative\">\n\n\t\t\t<header v-if=\"!route.params.url\" class=\"bg-light t-black radius-big pd-medium pos-relative mn-b-thin flex-v-center t-left flex-nowrap flex\">\n\t \t<h3 class=\"pos-relative flex-v-center flex-nowrap flex\">\n\t \t\t<span class=\"mn-r-thin\">Topics for </span>\n\n\t \t\t<Select \n\t\t :options=\"['today','week','month','year','all time']\"\n\t\t v-model:select=\"blog.state.filter.period\" \n\t\t placeholder=\"all time\"\n\t\t class=\"\n\t\t \tt-semi\n\t\t \tpos-relative \n\t\t \tw-max\n\t\t \tbg-main t-black\n\t\t \tpd-thin\n\t\t \tradius-medium\n\t\t h3\n\t\t \tt-center\n\t\t \"\n\t\t />\n\t \t</h3>\n\t\t\t</header>\n\n\t\t\t<router-view v-slot=\"{ Component, route }\">\n\t\t\t\t<transition name=\"scaleIn\" mode=\"out-in\">\n\t\t\t\t\t<component ref=\"page\" :key=\"route.query\" :is=\"Component\" />\n\t\t\t\t</transition>\n\t\t\t</router-view>\n\n\t\t</section>\n\n\t\t<div class=\"align-self-start bg-light radius-big pd-medium\">\n\t\t\t<div class=\"gap-thin flex-nowrap flex\">\n\t\t\t\t<p class=\"t-medium mn-b-small\">Popular Communities</p>\n\t\t\t\t\n\t\t\t\t<router-link \n\t\t\t\t\tv-if=\"auth.state.user._id\"\n\t\t\t\t\t:to=\"{\n\t\t\t\t\t\tname: 'Create Organization'\n\t\t\t\t\t}\"\n\t\t\t\t\tclass=\"t-medium cursor-pointer hover-scale-1 radius-extra flex-center flex i-medium bg-main\"\n\t\t\t\t>\n\t\t\t\t\t+\n\t\t\t\t</router-link>\n\t\t\t</div>\n\n\n\t\t\t<transition name=\"slide-fade\">\n\t\t\t\t<Feed\n\t\t :states=\"{\n\t\t empty: {\n\t\t title: 'No Organization Found',\n\t\t description: 'Currently, there are no organization available.'\n\t\t }\n\t\t }\"\n\t\t :store=\"{\n\t\t read: (options) => organizations.actions.read(options),\n\t\t state: organizations.state\n\t\t }\"\n\t\t :options=\"{\n\t\t \tuser: auth.state.user._id,\n\t\t\t\t\t\t\tsort: 'numberOfMemberships',\n\t\t\t\t\t\t\tcontain: ['blogposts'],\n\t\t\t\t\t\t\tlimit: 10\n\t\t }\"\n\t\t v-slot=\"{ \n\t\t items \n\t\t }\"\n\t\t >\n\t\t \t<CardOrganization \n\t \t\t\tv-for=\"organization in items\"\n\t \t:key=\"organization._id\" \n\t\t \t:organization=\"organization\"\n\t\t \t:user=\"auth.state.user\"\n\t\t \t:showProducts=\"false\"\n\t\t \t:showRating=\"false\"\n\t\t \t:showFeatured=\"false\"\n\t\t \t:showFollowers=\"false\"\n\t\t\t\t\t\t@updateMembership=\"handleMembershipUpdate\"\n\t\t\t\t\t\tclass=\"mn-b-thin w-100 pd-0 bg-white radius-big o-hidden\"\n\t\t\t />\n\t\t </Feed>\n\t\t\t</transition>\n\t\t</div>\n</div>\n</template>\n\n<script setup=\"props\">\n\timport { computed,onMounted, toRefs,ref } from 'vue'\n import { useRoute,useRouter } from 'vue-router'\n\n\timport Select from '@pf/src/components/Select/Select.vue'\n\timport Feed from '@pf/src/components/Feed/Feed.vue'\n\timport CardOrganization from '@pf/src/modules/organizations/components/blocks/CardOrganization.vue'\n\n\timport IconFeatured from '@pf/src/modules/icons/entities/IconFeatured.vue'\n\timport IconPopular from '@pf/src/modules/icons/entities/IconPopular.vue'\n\timport IconRecent from '@pf/src/modules/icons/entities/IconRecent.vue'\n\timport IconFollowing from '@pf/src/modules/icons/entities/IconFollowing.vue'\n\n \t// Import state\n\timport * as blog from '@pf/src/modules/community/store/blogposts.js';\n\timport * as auth from '@pf/src/modules/auth/views/store/auth'\n\timport * as organizations from '@pf/src/modules/organizations/store/organizations'\n\timport * as memberships from '@pf/src/modules/organizations/store/memberships'\n\n\t// State\n\tconst route = useRoute();\n\tconst router = useRouter();\n\n\tif (route.params.category === 'popular') blog.state.sort.param = 'views'; \n\tif (route.params.category === 'new') blog.state.sort.param = 'createdAt'; \n\n\n\tconst handleMembershipUpdate = ({ membership, status, target }, statusName, statusNumber) => {\n\t memberships.mutations.handleMembershipUpdate(organizations.state.current, membership, status, target, statusName, statusNumber)\n\t};\n\n</script>\n\n<style lang=\"scss\">\n\n</style>\n"],"names":["useRoute","useRouter","blog.state","memberships.mutations","organizations.state"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA6JC,UAAM,QAAQA,UAAAA;AACd,UAAM,SAASC,UAAAA;AAEf,QAAI,MAAM,OAAO,aAAa,UAAWC,WAAAA,MAAW,KAAK,QAAQ;AACjE,QAAI,MAAM,OAAO,aAAa,MAAOA,WAAAA,MAAW,KAAK,QAAQ;AAG7D,UAAM,yBAAyB,CAAC,EAAE,YAAY,QAAQ,OAAQ,GAAE,YAAY,iBAAiB;AAC3FC,4BAAsB,uBAAuBC,cAAAA,MAAoB,SAAS,YAAY,QAAQ,QAAQ,YAAY,YAAY;AAAA,IACjI;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -1,4 +1,4 @@
1
- import { resolveComponent, openBlock, createElementBlock, createElementVNode, normalizeClass, unref, createVNode, createTextVNode, createCommentVNode, withCtx, Transition, createBlock, resolveDynamicComponent, Fragment, renderList } from "vue";
1
+ import { resolveComponent, openBlock, createElementBlock, createElementVNode, normalizeClass, unref, createVNode, createTextVNode, createCommentVNode, createBlock, withCtx, Transition, resolveDynamicComponent, Fragment, renderList } from "vue";
2
2
  import { useRoute, useRouter } from "vue-router";
3
3
  import Select from "../../../../components/Select/Select.vue.js";
4
4
  import _sfc_main$5 from "../../../../components/Feed/Feed.vue.js";
@@ -13,11 +13,14 @@ import { actions, state as state$2 } from "../../../organizations/store/organiza
13
13
  import { mutations } from "../../../organizations/store/memberships.js";
14
14
  const _hoisted_1 = {
15
15
  style: { "grid-template-columns": "2fr 4fr 2fr" },
16
- class: "cols-3 gap-thin pd-thin"
16
+ class: "cols-3 gap-thin pd-t-zero pd-thin"
17
17
  };
18
- const _hoisted_2 = { class: "align-self-start pos-sticky pos-t-0 w-100 bg-light radius-big pd-medium p-medium gap-thin flex-column flex-nowrap flex" };
18
+ const _hoisted_2 = { class: "align-self-start pos-sticky pos-t-0 w-100 bg-light radius-big pd-medium p-medium gap-thin flex-column mobile:flex-row flex-nowrap flex z-index-2 o-scroll t-nowrap scroll-hide" };
19
19
  const _hoisted_3 = { class: "pos-relative" };
20
- const _hoisted_4 = { class: "bg-main t-black radius-big pd-medium pos-relative mn-b-thin flex-v-center t-left flex-nowrap flex" };
20
+ const _hoisted_4 = {
21
+ key: 0,
22
+ class: "bg-light t-black radius-big pd-medium pos-relative mn-b-thin flex-v-center t-left flex-nowrap flex"
23
+ };
21
24
  const _hoisted_5 = { class: "pos-relative flex-v-center flex-nowrap flex" };
22
25
  const _hoisted_6 = /* @__PURE__ */ createElementVNode("span", { class: "mn-r-thin" }, "Topics for ", -1);
23
26
  const _hoisted_7 = { class: "align-self-start bg-light radius-big pd-medium" };
@@ -79,20 +82,21 @@ const _sfc_main = {
79
82
  createVNode(_sfc_main$4, { class: "i-medium mn-r-thin t-transp" }),
80
83
  createTextVNode(" Following ")
81
84
  ], 2)) : createCommentVNode("", true),
82
- createVNode(_component_router_link, {
85
+ state$1.user._id ? (openBlock(), createBlock(_component_router_link, {
86
+ key: 1,
83
87
  to: {
84
88
  name: "Create BlogPost"
85
89
  },
86
- class: "button t-medium mn-t-small bg-main w-100"
90
+ class: "button t-medium bg-main w-100"
87
91
  }, {
88
92
  default: withCtx(() => [
89
93
  createTextVNode(" Create Post ")
90
94
  ]),
91
95
  _: 1
92
- })
96
+ })) : createCommentVNode("", true)
93
97
  ]),
94
98
  createElementVNode("section", _hoisted_3, [
95
- createElementVNode("header", _hoisted_4, [
99
+ !unref(route).params.url ? (openBlock(), createElementBlock("header", _hoisted_4, [
96
100
  createElementVNode("h3", _hoisted_5, [
97
101
  _hoisted_6,
98
102
  createVNode(Select, {
@@ -100,10 +104,10 @@ const _sfc_main = {
100
104
  select: state.filter.period,
101
105
  "onUpdate:select": _cache[4] || (_cache[4] = ($event) => state.filter.period = $event),
102
106
  placeholder: "all time",
103
- class: "t-semi pos-relative w-max bg-main t-black pd-thin radius-medium h3 t-center br-solid br-2px br-black-transp-10"
107
+ class: "t-semi pos-relative w-max bg-main t-black pd-thin radius-medium h3 t-center"
104
108
  }, null, 8, ["select"])
105
109
  ])
106
- ]),
110
+ ])) : createCommentVNode("", true),
107
111
  createVNode(_component_router_view, null, {
108
112
  default: withCtx(({ Component, route: route2 }) => [
109
113
  createVNode(Transition, {
@@ -1 +1 @@
1
- {"version":3,"file":"Community.vue.js","sources":["../../../../../../../src/modules/community/components/layouts/Community.vue"],"sourcesContent":["<template>\n\t<div style=\"grid-template-columns: 2fr 4fr 2fr;\" class=\"cols-3 gap-thin pd-thin\">\n\n\t\t<ul class=\"align-self-start pos-sticky pos-t-0 w-100 bg-light radius-big pd-medium p-medium gap-thin flex-column flex-nowrap flex\">\n\t\t\t<li \t\n\t\t\t\t:class=\"{'t-black bg-white': route.params.category === 'featured' }\" \t\t\t\t\t\n\t\t\t\t@click=\"() => { blog.state.sort.param = 'createdAt'; router.push({name: 'Blog', params: { category: 'featured' } })}\" \n\t\t\t\tclass=\"cursor-pointer flex-v-center flex t-medium pd-thin radius-extra\"\n\t\t\t>\n\t\t\t\t<IconFeatured class=\"i-medium mn-r-thin t-transp\"/>\n\t\t\t\tFeatured\n\t\t\t</li>\n\t\t\t<li \t\n\t\t\t\t:class=\"{'t-black bg-white': route.params.category === 'popular' }\"\t\t\t\t\t \t\t\t\t\n\t\t\t\t@click=\"() => { blog.state.sort.param = 'views'; router.push({name: 'Blog', params: { category: 'popular' } }) }\" \n\t\t\t\tclass=\"cursor-pointer t-medium flex-v-center flex pd-thin radius-extra\"\n\t\t\t>\t\n\t\t\t\t<IconPopular class=\"i-medium mn-r-thin t-transp\"/>\n\t\t\t\tPopular\n\t\t\t</li>\n\t\t\t<li \t\n\t\t\t\t:class=\"{'t-black bg-white': route.params.category === 'new'}\" \t\t\t\t\t\n\t\t\t\t@click=\"() => { blog.state.sort.param = 'createdAt'; router.push({name: 'Blog', params: { category: 'new' } })}\" \n\t\t\t\tclass=\"cursor-pointer t-medium flex-v-center flex pd-thin radius-extra\"\n\t\t\t>\n\t\t\t\t<IconRecent class=\"i-medium mn-r-thin t-transp\"/>\n\t\t\t\tRecent\n\t\t\t</li>\n\t\t\t<li \t\n\t\t\t\tv-if=\"auth.state.user._id\"\n\t\t\t\t:class=\"{'t-black bg-white': route.params.category === 'following'}\" \t\t\n\t\t\t\t@click=\"() => { blog.state.sort.param = 'createdAt'; router.push({name: 'Blog', params: { category: 'following' } })}\" \n\t\t\t\tclass=\"cursor-pointer t-medium flex-v-center flex pd-thin radius-extra\"\n\t\t\t>\n\t\t\t\t<IconFollowing class=\"i-medium mn-r-thin t-transp\"/>\n\t\t\t\tFollowing\n\t\t\t</li>\n\n\t\t\t<router-link \n\t\t\t\t:to=\"{\n\t\t\t\t\tname: 'Create BlogPost'\n\t\t\t\t}\" \n\t\t\t\tclass=\"button t-medium mn-t-small bg-main w-100\"\n\t\t\t>\n\t\t\t\tCreate Post\n\t\t\t</router-link>\n\t\t</ul>\n\n\t\t<section class=\"pos-relative\">\n\n\t\t\t<header class=\"bg-main t-black radius-big pd-medium pos-relative mn-b-thin flex-v-center t-left flex-nowrap flex\">\n\t \t<h3 class=\"pos-relative flex-v-center flex-nowrap flex\">\n\t \t\t<span class=\"mn-r-thin\">Topics for </span>\n\n\t \t\t<Select \n\t\t :options=\"['today','week','month','year','all time']\"\n\t\t v-model:select=\"blog.state.filter.period\" \n\t\t placeholder=\"all time\"\n\t\t class=\"\n\t\t \tt-semi\n\t\t \tpos-relative \n\t\t \tw-max\n\t\t \tbg-main t-black\n\t\t \tpd-thin\n\t\t \tradius-medium\n\t\t h3\n\t\t \tt-center\n\t\t \tbr-solid\n\t\t \tbr-2px\n\t\t \tbr-black-transp-10\n\t\t \"\n\t\t />\n\t \t</h3>\n\t\t\t</header>\n\n\t\t\t<router-view v-slot=\"{ Component, route }\">\n\t\t\t\t<transition name=\"scaleIn\" mode=\"out-in\">\n\t\t\t\t\t<component ref=\"page\" :key=\"route.query\" :is=\"Component\" />\n\t\t\t\t</transition>\n\t\t\t</router-view>\n\n\t\t</section>\n\n\t\t<div class=\"align-self-start bg-light radius-big pd-medium\">\n\t\t\t<div class=\"gap-thin flex-nowrap flex\">\n\t\t\t\t<p class=\"t-medium mn-b-small\">Popular Communities</p>\n\t\t\t\t\n\t\t\t\t<router-link \n\t\t\t\t\tv-if=\"auth.state.user._id\"\n\t\t\t\t\t:to=\"{\n\t\t\t\t\t\tname: 'Create Organization'\n\t\t\t\t\t}\"\n\t\t\t\t\tclass=\"t-medium cursor-pointer hover-scale-1 radius-extra flex-center flex i-medium bg-main\"\n\t\t\t\t>\n\t\t\t\t\t+\n\t\t\t\t</router-link>\n\t\t\t</div>\n\n\n\t\t\t<transition name=\"slide-fade\">\n\t\t\t\t<Feed\n\t\t :states=\"{\n\t\t empty: {\n\t\t title: 'No Organization Found',\n\t\t description: 'Currently, there are no organization available.'\n\t\t }\n\t\t }\"\n\t\t :store=\"{\n\t\t read: (options) => organizations.actions.read(options),\n\t\t state: organizations.state\n\t\t }\"\n\t\t :options=\"{\n\t\t \tuser: auth.state.user._id,\n\t\t\t\t\t\t\tsort: 'numberOfMemberships',\n\t\t\t\t\t\t\tcontain: ['blogposts'],\n\t\t\t\t\t\t\tlimit: 10\n\t\t }\"\n\t\t v-slot=\"{ \n\t\t items \n\t\t }\"\n\t\t >\n\t\t \t<CardOrganization \n\t \t\t\tv-for=\"organization in items\"\n\t \t:key=\"organization._id\" \n\t\t \t:organization=\"organization\"\n\t\t \t:user=\"auth.state.user\"\n\t\t \t:showProducts=\"false\"\n\t\t \t:showRating=\"false\"\n\t\t \t:showFeatured=\"false\"\n\t\t \t:showFollowers=\"false\"\n\t\t\t\t\t\t@updateMembership=\"handleMembershipUpdate\"\n\t\t\t\t\t\tclass=\"mn-b-thin w-100 pd-0 bg-white radius-big o-hidden\"\n\t\t\t />\n\t\t </Feed>\n\t\t\t</transition>\n\t\t</div>\n</div>\n</template>\n\n<script setup=\"props\">\n\timport { computed,onMounted, toRefs,ref } from 'vue'\n import { useRoute,useRouter } from 'vue-router'\n\n\timport Select from '@pf/src/components/Select/Select.vue'\n\timport Feed from '@pf/src/components/Feed/Feed.vue'\n\timport CardOrganization from '@pf/src/modules/organizations/components/blocks/CardOrganization.vue'\n\n\timport IconFeatured from '@pf/src/modules/icons/entities/IconFeatured.vue'\n\timport IconPopular from '@pf/src/modules/icons/entities/IconPopular.vue'\n\timport IconRecent from '@pf/src/modules/icons/entities/IconRecent.vue'\n\timport IconFollowing from '@pf/src/modules/icons/entities/IconFollowing.vue'\n\n \t// Import state\n\timport * as blog from '@pf/src/modules/community/store/blogposts.js';\n\timport * as auth from '@pf/src/modules/auth/views/store/auth'\n\timport * as organizations from '@pf/src/modules/organizations/store/organizations'\n\timport * as memberships from '@pf/src/modules/organizations/store/memberships'\n\n\t// State\n\tconst route = useRoute();\n\tconst router = useRouter();\n\n\tif (route.params.category === 'popular') blog.state.sort.param = 'views'; \n\tif (route.params.category === 'new') blog.state.sort.param = 'createdAt'; \n\n\n\tconst handleMembershipUpdate = ({ membership, status, target }, statusName, statusNumber) => {\n\t memberships.mutations.handleMembershipUpdate(organizations.state.current, membership, status, target, statusName, statusNumber)\n\t};\n\n</script>\n\n<style lang=\"scss\">\n\n</style>\n"],"names":["blog.state","memberships.mutations","organizations.state"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AA+JC,UAAM,QAAQ;AACd,UAAM,SAAS;AAEf,QAAI,MAAM,OAAO,aAAa,UAAWA,OAAW,KAAK,QAAQ;AACjE,QAAI,MAAM,OAAO,aAAa,MAAOA,OAAW,KAAK,QAAQ;AAG7D,UAAM,yBAAyB,CAAC,EAAE,YAAY,QAAQ,OAAQ,GAAE,YAAY,iBAAiB;AAC3FC,gBAAsB,uBAAuBC,QAAoB,SAAS,YAAY,QAAQ,QAAQ,YAAY,YAAY;AAAA,IACjI;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"Community.vue.js","sources":["../../../../../../../src/modules/community/components/layouts/Community.vue"],"sourcesContent":["<template>\n\t<div style=\"grid-template-columns: 2fr 4fr 2fr;\" class=\"cols-3 gap-thin pd-t-zero pd-thin\">\n\n\t\t<ul class=\"align-self-start pos-sticky pos-t-0 w-100 bg-light radius-big pd-medium p-medium gap-thin flex-column mobile:flex-row flex-nowrap flex z-index-2 o-scroll t-nowrap scroll-hide\">\n\t\t\t<li \t\n\t\t\t\t:class=\"{'t-black bg-white': route.params.category === 'featured' }\" \t\t\t\t\t\n\t\t\t\t@click=\"() => { blog.state.sort.param = 'createdAt'; router.push({name: 'Blog', params: { category: 'featured' } })}\" \n\t\t\t\tclass=\"cursor-pointer flex-v-center flex t-medium pd-thin radius-extra\"\n\t\t\t>\n\t\t\t\t<IconFeatured class=\"i-medium mn-r-thin t-transp\"/>\n\t\t\t\tFeatured\n\t\t\t</li>\n\t\t\t<li \t\n\t\t\t\t:class=\"{'t-black bg-white': route.params.category === 'popular' }\"\t\t\t\t\t \t\t\t\t\n\t\t\t\t@click=\"() => { blog.state.sort.param = 'views'; router.push({name: 'Blog', params: { category: 'popular' } }) }\" \n\t\t\t\tclass=\"cursor-pointer t-medium flex-v-center flex pd-thin radius-extra\"\n\t\t\t>\t\n\t\t\t\t<IconPopular class=\"i-medium mn-r-thin t-transp\"/>\n\t\t\t\tPopular\n\t\t\t</li>\n\t\t\t<li \t\n\t\t\t\t:class=\"{'t-black bg-white': route.params.category === 'new'}\" \t\t\t\t\t\n\t\t\t\t@click=\"() => { blog.state.sort.param = 'createdAt'; router.push({name: 'Blog', params: { category: 'new' } })}\" \n\t\t\t\tclass=\"cursor-pointer t-medium flex-v-center flex pd-thin radius-extra\"\n\t\t\t>\n\t\t\t\t<IconRecent class=\"i-medium mn-r-thin t-transp\"/>\n\t\t\t\tRecent\n\t\t\t</li>\n\t\t\t<li \t\n\t\t\t\tv-if=\"auth.state.user._id\"\n\t\t\t\t:class=\"{'t-black bg-white': route.params.category === 'following'}\" \t\t\n\t\t\t\t@click=\"() => { blog.state.sort.param = 'createdAt'; router.push({name: 'Blog', params: { category: 'following' } })}\" \n\t\t\t\tclass=\"cursor-pointer t-medium flex-v-center flex pd-thin radius-extra\"\n\t\t\t>\n\t\t\t\t<IconFollowing class=\"i-medium mn-r-thin t-transp\"/>\n\t\t\t\tFollowing\n\t\t\t</li>\n\n\t\t\t<router-link \n\t\t\t\tv-if=\"auth.state.user._id\"\n\t\t\t\t:to=\"{\n\t\t\t\t\tname: 'Create BlogPost'\n\t\t\t\t}\" \n\t\t\t\tclass=\"button t-medium bg-main w-100\"\n\t\t\t>\n\t\t\t\tCreate Post\n\t\t\t</router-link>\n\t\t</ul>\n\n\t\t<section class=\"pos-relative\">\n\n\t\t\t<header v-if=\"!route.params.url\" class=\"bg-light t-black radius-big pd-medium pos-relative mn-b-thin flex-v-center t-left flex-nowrap flex\">\n\t \t<h3 class=\"pos-relative flex-v-center flex-nowrap flex\">\n\t \t\t<span class=\"mn-r-thin\">Topics for </span>\n\n\t \t\t<Select \n\t\t :options=\"['today','week','month','year','all time']\"\n\t\t v-model:select=\"blog.state.filter.period\" \n\t\t placeholder=\"all time\"\n\t\t class=\"\n\t\t \tt-semi\n\t\t \tpos-relative \n\t\t \tw-max\n\t\t \tbg-main t-black\n\t\t \tpd-thin\n\t\t \tradius-medium\n\t\t h3\n\t\t \tt-center\n\t\t \"\n\t\t />\n\t \t</h3>\n\t\t\t</header>\n\n\t\t\t<router-view v-slot=\"{ Component, route }\">\n\t\t\t\t<transition name=\"scaleIn\" mode=\"out-in\">\n\t\t\t\t\t<component ref=\"page\" :key=\"route.query\" :is=\"Component\" />\n\t\t\t\t</transition>\n\t\t\t</router-view>\n\n\t\t</section>\n\n\t\t<div class=\"align-self-start bg-light radius-big pd-medium\">\n\t\t\t<div class=\"gap-thin flex-nowrap flex\">\n\t\t\t\t<p class=\"t-medium mn-b-small\">Popular Communities</p>\n\t\t\t\t\n\t\t\t\t<router-link \n\t\t\t\t\tv-if=\"auth.state.user._id\"\n\t\t\t\t\t:to=\"{\n\t\t\t\t\t\tname: 'Create Organization'\n\t\t\t\t\t}\"\n\t\t\t\t\tclass=\"t-medium cursor-pointer hover-scale-1 radius-extra flex-center flex i-medium bg-main\"\n\t\t\t\t>\n\t\t\t\t\t+\n\t\t\t\t</router-link>\n\t\t\t</div>\n\n\n\t\t\t<transition name=\"slide-fade\">\n\t\t\t\t<Feed\n\t\t :states=\"{\n\t\t empty: {\n\t\t title: 'No Organization Found',\n\t\t description: 'Currently, there are no organization available.'\n\t\t }\n\t\t }\"\n\t\t :store=\"{\n\t\t read: (options) => organizations.actions.read(options),\n\t\t state: organizations.state\n\t\t }\"\n\t\t :options=\"{\n\t\t \tuser: auth.state.user._id,\n\t\t\t\t\t\t\tsort: 'numberOfMemberships',\n\t\t\t\t\t\t\tcontain: ['blogposts'],\n\t\t\t\t\t\t\tlimit: 10\n\t\t }\"\n\t\t v-slot=\"{ \n\t\t items \n\t\t }\"\n\t\t >\n\t\t \t<CardOrganization \n\t \t\t\tv-for=\"organization in items\"\n\t \t:key=\"organization._id\" \n\t\t \t:organization=\"organization\"\n\t\t \t:user=\"auth.state.user\"\n\t\t \t:showProducts=\"false\"\n\t\t \t:showRating=\"false\"\n\t\t \t:showFeatured=\"false\"\n\t\t \t:showFollowers=\"false\"\n\t\t\t\t\t\t@updateMembership=\"handleMembershipUpdate\"\n\t\t\t\t\t\tclass=\"mn-b-thin w-100 pd-0 bg-white radius-big o-hidden\"\n\t\t\t />\n\t\t </Feed>\n\t\t\t</transition>\n\t\t</div>\n</div>\n</template>\n\n<script setup=\"props\">\n\timport { computed,onMounted, toRefs,ref } from 'vue'\n import { useRoute,useRouter } from 'vue-router'\n\n\timport Select from '@pf/src/components/Select/Select.vue'\n\timport Feed from '@pf/src/components/Feed/Feed.vue'\n\timport CardOrganization from '@pf/src/modules/organizations/components/blocks/CardOrganization.vue'\n\n\timport IconFeatured from '@pf/src/modules/icons/entities/IconFeatured.vue'\n\timport IconPopular from '@pf/src/modules/icons/entities/IconPopular.vue'\n\timport IconRecent from '@pf/src/modules/icons/entities/IconRecent.vue'\n\timport IconFollowing from '@pf/src/modules/icons/entities/IconFollowing.vue'\n\n \t// Import state\n\timport * as blog from '@pf/src/modules/community/store/blogposts.js';\n\timport * as auth from '@pf/src/modules/auth/views/store/auth'\n\timport * as organizations from '@pf/src/modules/organizations/store/organizations'\n\timport * as memberships from '@pf/src/modules/organizations/store/memberships'\n\n\t// State\n\tconst route = useRoute();\n\tconst router = useRouter();\n\n\tif (route.params.category === 'popular') blog.state.sort.param = 'views'; \n\tif (route.params.category === 'new') blog.state.sort.param = 'createdAt'; \n\n\n\tconst handleMembershipUpdate = ({ membership, status, target }, statusName, statusNumber) => {\n\t memberships.mutations.handleMembershipUpdate(organizations.state.current, membership, status, target, statusName, statusNumber)\n\t};\n\n</script>\n\n<style lang=\"scss\">\n\n</style>\n"],"names":["blog.state","memberships.mutations","organizations.state"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA6JC,UAAM,QAAQ;AACd,UAAM,SAAS;AAEf,QAAI,MAAM,OAAO,aAAa,UAAWA,OAAW,KAAK,QAAQ;AACjE,QAAI,MAAM,OAAO,aAAa,MAAOA,OAAW,KAAK,QAAQ;AAG7D,UAAM,yBAAyB,CAAC,EAAE,YAAY,QAAQ,OAAQ,GAAE,YAAY,iBAAiB;AAC3FC,gBAAsB,uBAAuBC,QAAoB,SAAS,YAAY,QAAQ,QAAQ,YAAY,YAAY;AAAA,IACjI;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -2,68 +2,82 @@
2
2
  Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
3
3
  const vue = require("vue");
4
4
  const vue_f36acd1f = require("../../../../../../node_modules/@unhead/vue/dist/shared/vue.f36acd1f.cjs");
5
- ;/* empty css */
5
+ ;/* empty css */
6
6
  const EmptyState = require("../../../../components/EmptyState/EmptyState.vue.cjs");
7
7
  const CardBlogpost = require("../blocks/CardBlogpost.vue.cjs");
8
8
  const SkeletonBlogpost = require("../../../icons/skeletons/SkeletonBlogpost.vue.cjs");
9
- const Publics = require("../../../organizations/components/sections/Publics.vue.cjs");
9
+ const vueRouter = require("vue-router");
10
+ ;/* empty css */
11
+ ;/* empty css */
12
+ const auth = require("../../../auth/views/store/auth.cjs");
13
+ require("../../../organizations/store/memberships.cjs");
14
+ require("../../../organizations/store/organizations.cjs");
15
+ ;/* empty css */
10
16
  const Comments = require("../sections/Comments.vue.cjs");
11
17
  const Viewer = require("../../../constructor/components/sections/Viewer.vue.cjs");
12
18
  const blogposts = require("../../store/blogposts.cjs");
13
- const auth = require("../../../auth/views/store/auth.cjs");
14
- const vueRouter = require("vue-router");
15
- const _hoisted_1 = { class: "pd-thin" };
16
- const _hoisted_2 = ["href"];
17
- const _hoisted_3 = /* @__PURE__ */ vue.createElementVNode("h3", { class: "mn-b-small" }, "Recommended Communities", -1);
19
+ const _hoisted_1 = ["href"];
18
20
  const _sfc_main = {
19
21
  __name: "BlogPost",
20
- async setup(__props) {
21
- let __temp, __restore;
22
+ setup(__props) {
22
23
  const route = vueRouter.useRoute();
23
- const blogpost = vue.ref(null);
24
- const isLoading = vue.ref(true);
24
+ const blogpost = vue.computed(() => blogposts.state.current);
25
+ const isLoading = vue.ref(false);
25
26
  const canShare = vue.ref(false);
26
- vue.onMounted(() => {
27
- canShare.value = !!navigator.share;
28
- });
29
- isLoading.value = true;
30
- const data = ([__temp, __restore] = vue.withAsyncContext(() => blogposts.read({ user: auth.state.user._id, url: route.params.url })), __temp = await __temp, __restore(), __temp);
31
- blogpost.value = data[0];
32
- isLoading.value = false;
33
- vue.computed(() => {
27
+ const error = vue.ref(null);
28
+ async function fetchBlogpost() {
34
29
  var _a;
35
- return (_a = blogpost.value) == null ? void 0 : _a.content.find((block) => block.type === "ImageUpload");
30
+ try {
31
+ isLoading.value = true;
32
+ const data = await blogposts.read({ user: (_a = auth.state.user) == null ? void 0 : _a._id, url: route.params.url });
33
+ blogpost.value = data[0];
34
+ blogposts.state.current = data[0];
35
+ } catch (err) {
36
+ error.value = err;
37
+ console.error("Error fetching blogpost:", err);
38
+ } finally {
39
+ isLoading.value = false;
40
+ }
41
+ }
42
+ vue.onServerPrefetch(async () => {
43
+ await fetchBlogpost();
36
44
  });
37
- vue.computed(() => {
38
- var _a;
39
- return (_a = blogpost.value) == null ? void 0 : _a.content.find((block) => block.type === "Video");
45
+ vue.onMounted(async () => {
46
+ if (!blogpost.value || blogpost.value.url !== route.params.url) {
47
+ await fetchBlogpost();
48
+ }
49
+ canShare.value = !!navigator.share;
50
+ });
51
+ const firstImage = vue.computed(() => {
52
+ var _a, _b;
53
+ return (_b = (_a = blogpost.value) == null ? void 0 : _a.content) == null ? void 0 : _b.find((block) => block.type === "ImageUpload");
40
54
  });
41
55
  const firstText = vue.computed(() => {
42
- var _a;
43
- return (_a = blogpost.value) == null ? void 0 : _a.content[2];
56
+ var _a, _b;
57
+ return (_b = (_a = blogpost.value) == null ? void 0 : _a.content) == null ? void 0 : _b.find(
58
+ (block) => block.type === "Textarea" && block.class !== "h2"
59
+ );
44
60
  });
45
61
  const metadata = vue.computed(() => {
46
- var _a, _b, _c, _d, _e, _f;
62
+ var _a, _b, _c, _d, _e, _f, _g, _h, _i;
47
63
  return {
48
64
  title: (_a = blogpost.value) == null ? void 0 : _a.name,
49
65
  description: (_b = firstText.value) == null ? void 0 : _b.content.slice(0, 120),
50
66
  meta: [
51
67
  { hid: "description", name: "description", content: (_c = firstText.value) == null ? void 0 : _c.content.slice(0, 120) },
52
- // { hid: 'keywords', name: 'keywords', content: t('meta.keywords') },
53
68
  { hid: "og:title", property: "og:title", content: (_d = blogpost.value) == null ? void 0 : _d.name },
54
69
  { hid: "og:description", property: "og:description", content: (_e = firstText.value) == null ? void 0 : _e.content.slice(0, 120) },
55
- // { hid: 'og:image', property: 'og:image', content: base_url + '/favicon/cover.jpg' },
56
- // { hid: 'og:url', property: 'og:url', content: current_url.value },
57
- { hid: "twitter:title", name: "twitter:title", content: (_f = blogpost.value) == null ? void 0 : _f.name },
58
- { hid: "twitter:description", name: "twitter:description", content: firstText.value }
59
- // { hid: 'twitter:image', name: 'twitter:image', content: base_url + '/favicon/cover.jpg' },
60
- // { hid: 'twitter:card', name: 'twitter:card', content: t('meta.twitter.card') },
70
+ { hid: "og:image", property: "og:image", content: ((_f = firstImage.value) == null ? void 0 : _f.content) ? `${process.env.FILE_SERVER_URL}${firstImage.value.content}` : `${process.env.FILE_SERVER_URL}/favicon/cover.jpg` },
71
+ { hid: "twitter:title", name: "twitter:title", content: (_g = blogpost.value) == null ? void 0 : _g.name },
72
+ { hid: "twitter:description", name: "twitter:description", content: (_h = firstText.value) == null ? void 0 : _h.content.slice(0, 120) },
73
+ { hid: "twitter:image", name: "twitter:image", content: ((_i = firstImage.value) == null ? void 0 : _i.content) ? `${process.env.FILE_SERVER_URL}${firstImage.value.content}` : `${process.env.FILE_SERVER_URL}/favicon/cover.jpg` },
74
+ { hid: "twitter:card", name: "twitter:card", content: "summary_large_image" }
61
75
  ]
62
76
  };
63
77
  });
64
- vue_f36acd1f.u(metadata.value);
78
+ vue_f36acd1f.u(metadata);
65
79
  return (_ctx, _cache) => {
66
- return vue.openBlock(), vue.createElementBlock("section", _hoisted_1, [
80
+ return vue.openBlock(), vue.createElementBlock("section", null, [
67
81
  vue.createVNode(vue.TransitionGroup, {
68
82
  tag: "ul",
69
83
  name: "fade",
@@ -100,7 +114,7 @@ const _sfc_main = {
100
114
  user: auth.state.user._id,
101
115
  type: "blogpostPage",
102
116
  hideTitle: true,
103
- class: "mn-b-medium"
117
+ class: "mn-b-thin"
104
118
  }, {
105
119
  default: vue.withCtx(() => [
106
120
  blogpost.value && blogpost.value.content ? (vue.openBlock(), vue.createBlock(Viewer.default, {
@@ -112,17 +126,16 @@ const _sfc_main = {
112
126
  href: blogpost.value.source,
113
127
  target: "_blank",
114
128
  class: "mn-b-semi d-block w-max radius-big pd-thin bg-black t-white"
115
- }, " Check Source 🔗 ", 8, _hoisted_2)) : vue.createCommentVNode("", true)
129
+ }, " Check Source 🔗 ", 8, _hoisted_1)) : vue.createCommentVNode("", true)
116
130
  ]),
117
131
  _: 1
118
132
  }, 8, ["blogpost", "user"])) : vue.createCommentVNode("", true),
119
- _hoisted_3,
120
- vue.createVNode(Publics.default, { class: "mn-b-small" }),
121
133
  !isLoading.value && blogpost.value ? (vue.openBlock(), vue.createBlock(Comments.default, {
122
134
  key: 1,
123
135
  type: "blogpost",
124
136
  target: blogpost.value._id,
125
- owner: auth.state.user._id
137
+ owner: auth.state.user._id,
138
+ class: "bg-light radius-big pd-medium"
126
139
  }, null, 8, ["target", "owner"])) : vue.createCommentVNode("", true)
127
140
  ]),
128
141
  _: 1
@@ -1 +1 @@
1
- {"version":3,"file":"BlogPost.vue.cjs","sources":["../../../../../../../src/modules/community/components/pages/BlogPost.vue"],"sourcesContent":["<template>\n <section class=\"pd-thin\">\n <TransitionGroup tag=\"ul\" name=\"fade\" class=\"o-hidden bg-light radius-big\">\n <SkeletonBlogpost\n v-if=\"isLoading\"\n v-for=\"i in 3\" :key=\"i\"\n />\n </TransitionGroup>\n\n <transition \n name=\"fade\"\n >\n <EmptyState \n v-if=\"!isLoading && !blogpost\"\n title=\"No Blogpost Found\"\n description=\"Currently, there are no blogposts available. Please check back later.\"\n class=\"pd-medium mn-b-thin bg-light radius-big\"\n />\n </transition>\n\n\n\t\t \n\n <TransitionGroup tag=\"ul\" name=\"fade\" class=\"container\">\n \t <!-- <button @click=\"share\" >\n\t\t\t Поделиться\n\t\t\t </button>\n\t\t\t -->\n \t<CardBlogpost \n v-if=\"!isLoading && blogpost\"\n @click=\"$router.push({name: 'Blogpost', params: {url: blogpost.url}})\" \n :blogpost=\"blogpost\" \n :user=\"auth.state.user._id\"\n :type=\"'blogpostPage'\"\n :hideTitle=\"true\"\n class=\"mn-b-medium\"\n >\n\n\t <Viewer\n\t v-if=\"blogpost && blogpost.content\"\n\t :content=\"blogpost.content\"\n\t />\n\n\t\t\t\t<a v-if=\"blogpost.source\" :href=\"blogpost.source\" target=\"_blank\" class=\"mn-b-semi d-block w-max radius-big pd-thin bg-black t-white\">\n\t\t\t\t\tCheck Source 🔗\n\t\t\t\t</a>\n\t\t\t\n </CardBlogpost>\n\n \t<h3 class=\"mn-b-small\">Recommended Communities</h3>\n\t\t<Publics \n\t\t\tclass=\"mn-b-small\"\n\t\t/>\n\n <Comments \n v-if=\"!isLoading && blogpost\" \n :type=\"'blogpost'\" \n :target=\"blogpost._id\" \n :owner=\"auth.state.user._id\"\n />\n \n </TransitionGroup> \n \n </section>\n</template>\n\n<script setup>\n\timport { ref, onMounted, computed } from 'vue';\n\timport { useHead } from '@unhead/vue'\n\n\n\timport Loader from '@pf/src/components/Loader/Loader.vue';\n\timport EmptyState from '@pf/src/components/EmptyState/EmptyState.vue';\n\n\timport CardBlogpost from '@pf/src/modules/community/components/blocks/CardBlogpost.vue';\n\timport SkeletonBlogpost from '@pf/src/modules/icons/skeletons/SkeletonBlogpost.vue'\n\timport Publics \t\tfrom '@pf/src/modules/organizations/components/sections/Publics.vue'\n\timport Comments from '@pf/src/modules/community/components/sections/Comments.vue';\n\n\timport Viewer from '@pf/src/modules/constructor/components/sections/Viewer.vue';\n\n\timport * as blog from '@pf/src/modules/community/store/blogposts.js';\n\timport * as auth from '@pf/src/modules/auth/views/store/auth';\n\t \n\timport { useRoute } from 'vue-router';\n\n\tconst route = useRoute();\n\n\tconst blogpost = ref(null);\n\tconst isLoading = ref(true);\n\n\tconst canShare = ref(false);\n\n\tonMounted(() => {\n\t canShare.value = !!navigator.share;\n\t});\n\n\tconst share = async () => {\n\t if (!canShare.value) return;\n\n\t console.log('share')\n\t try {\n\t await navigator.share({\n\t title: 'Заголовок вашего контента',\n\t text: 'Описание вашего контента',\n\t // url: window.location.href,\n\t });\n\t console.log('Контент успешно отправлен');\n\t } catch (error) {\n\t console.error('Ошибка при отправке:', error);\n\t }\n\t};\n\n\t// onMounted(async () => {\n\t\tisLoading.value = true;\n\n\t\t// NOTE: You might need to change the method here to fetch blogposts\n\t\tconst data = await blog.read({ user: auth.state.user._id, url: route.params.url });\n\n\t\tblogpost.value = data[0];\n\t\tisLoading.value = false;\n\t// });\n\n\t const firstImage = computed(() => {\n\t return blogpost.value?.content.find(block => block.type === 'ImageUpload');\n\t});\n\n\tconst firstVideo = computed(() => {\n\t return blogpost.value?.content.find(block => block.type === 'Video');\n\t});\n\n\tconst firstText = computed(() => {\n\t return blogpost.value?.content[2]\n\t});\n\n\t const metadata = computed(() => {return {\n title: blogpost.value?.name,\n description: firstText.value?.content.slice(0,120),\n meta: [\n { hid: 'description', name: 'description', content: firstText.value?.content.slice(0,120) },\n // { hid: 'keywords', name: 'keywords', content: t('meta.keywords') },\n { hid: 'og:title', property: 'og:title', content: blogpost.value?.name },\n { hid: 'og:description', property: 'og:description', content: firstText.value?.content.slice(0,120) },\n // { hid: 'og:image', property: 'og:image', content: base_url + '/favicon/cover.jpg' },\n // { hid: 'og:url', property: 'og:url', content: current_url.value },\n { hid: 'twitter:title', name: 'twitter:title', content: blogpost.value?.name },\n { hid: 'twitter:description', name: 'twitter:description', content: firstText.value },\n // { hid: 'twitter:image', name: 'twitter:image', content: base_url + '/favicon/cover.jpg' },\n // { hid: 'twitter:card', name: 'twitter:card', content: t('meta.twitter.card') },\n ],\n }});\nuseHead(metadata.value)\n</script>\n\n<style lang=\"scss\">\n\n</style>\n"],"names":["useRoute","ref","onMounted","_withAsyncContext","blog.read","auth.state","computed","useHead"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAsFC,UAAM,QAAQA,UAAAA;AAEd,UAAM,WAAWC,QAAI,IAAI;AACzB,UAAM,YAAYA,QAAI,IAAI;AAE1B,UAAM,WAAWA,QAAI,KAAK;AAE1BC,QAAAA,UAAU,MAAM;AACd,eAAS,QAAQ,CAAC,CAAC,UAAU;AAAA,IAChC,CAAE;AAmBA,cAAU,QAAQ;AAGlB,UAAM,QAAO,CAAA,QAAA,SAAA,IAAAC,IAAAA,iBAAA,MAAMC,UAAS,KAAC,EAAE,MAAMC,KAAU,MAAC,KAAK,KAAK,KAAK,MAAM,OAAO,IAAG,CAAE,CAAA;AAEjF,aAAS,QAAQ,KAAK,CAAC;AACvB,cAAU,QAAQ;AAGCC,QAAAA,SAAS,MAAM;;AACjC,cAAO,cAAS,UAAT,mBAAgB,QAAQ,KAAK,WAAS,MAAM,SAAS;AAAA,IAC/D,CAAE;AAEkBA,QAAAA,SAAS,MAAM;;AAChC,cAAO,cAAS,UAAT,mBAAgB,QAAQ,KAAK,WAAS,MAAM,SAAS;AAAA,IAC/D,CAAE;AAED,UAAM,YAAYA,IAAAA,SAAS,MAAM;;AAC/B,cAAO,cAAS,UAAT,mBAAgB,QAAQ;AAAA,IAClC,CAAE;AAEA,UAAM,WAAWA,aAAS,MAAM;;AAAC,aAAO;AAAA,QACpC,QAAO,cAAS,UAAT,mBAAgB;AAAA,QACvB,cAAa,eAAU,UAAV,mBAAiB,QAAQ,MAAM,GAAE;AAAA,QAC9C,MAAM;AAAA,UACJ,EAAE,KAAK,eAAe,MAAM,eAAe,UAAS,eAAU,UAAV,mBAAiB,QAAQ,MAAM,GAAE,KAAM;AAAA;AAAA,UAE3F,EAAE,KAAK,YAAY,UAAU,YAAY,UAAS,cAAS,UAAT,mBAAgB,KAAM;AAAA,UACxE,EAAE,KAAK,kBAAkB,UAAU,kBAAkB,UAAS,eAAU,UAAV,mBAAiB,QAAQ,MAAM,GAAE,KAAM;AAAA;AAAA;AAAA,UAGrG,EAAE,KAAK,iBAAiB,MAAM,iBAAiB,UAAU,cAAS,UAAT,mBAAgB,KAAM;AAAA,UAC/E,EAAE,KAAK,uBAAuB,MAAM,uBAAuB,SAAS,UAAU,MAAO;AAAA;AAAA;AAAA,QAGtF;AAAA,MACF;AAAA,IAAA,CAAC;AACNC,iBAAAA,EAAQ,SAAS,KAAK;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"BlogPost.vue.cjs","sources":["../../../../../../../src/modules/community/components/pages/BlogPost.vue"],"sourcesContent":["<template>\n <section>\n <TransitionGroup tag=\"ul\" name=\"fade\" class=\"o-hidden bg-light radius-big\">\n <SkeletonBlogpost\n v-if=\"isLoading\"\n v-for=\"i in 3\" :key=\"i\"\n />\n </TransitionGroup>\n <transition \n name=\"fade\"\n >\n <EmptyState \n v-if=\"!isLoading && !blogpost\"\n title=\"No Blogpost Found\"\n description=\"Currently, there are no blogposts available. Please check back later.\"\n class=\"pd-medium mn-b-thin bg-light radius-big\"\n />\n </transition>\n\n <TransitionGroup tag=\"ul\" name=\"fade\" class=\"container\">\n \t <!-- <button @click=\"share\" >\n\t\t\t Поделиться\n\t\t\t </button>\n\t\t\t -->\n \t<CardBlogpost \n v-if=\"!isLoading && blogpost\"\n @click=\"$router.push({name: 'Blogpost', params: {url: blogpost.url}})\" \n :blogpost=\"blogpost\" \n :user=\"auth.state.user._id\"\n :type=\"'blogpostPage'\"\n :hideTitle=\"true\"\n class=\"mn-b-thin\"\n >\n\n \t <Viewer\n \t v-if=\"blogpost && blogpost.content\"\n \t :content=\"blogpost.content\"\n \t />\n\n \t\t\t\t<a v-if=\"blogpost.source\" :href=\"blogpost.source\" target=\"_blank\" class=\"mn-b-semi d-block w-max radius-big pd-thin bg-black t-white\">\n \t\t\t\t\tCheck Source 🔗\n \t\t\t\t</a>\n \t\t\t\n </CardBlogpost>\n\n \t<!-- <h3 class=\"mn-b-small\">Recommended Communities</h3>\n \t\t<Publics \n \t\t\tclass=\"mn-b-small\"\n \t\t/> -->\n\n <Comments \n v-if=\"!isLoading && blogpost\" \n :type=\"'blogpost'\" \n :target=\"blogpost._id\" \n :owner=\"auth.state.user._id\"\n class=\"bg-light radius-big pd-medium\"\n />\n \n </TransitionGroup> \n \n </section>\n</template>\n\n<script setup>\nimport { ref, onMounted, computed, onServerPrefetch, watch } from 'vue';\nimport { useHead } from '@unhead/vue'\nimport Loader from '@pf/src/components/Loader/Loader.vue';\nimport EmptyState from '@pf/src/components/EmptyState/EmptyState.vue';\nimport CardBlogpost from '@pf/src/modules/community/components/blocks/CardBlogpost.vue';\nimport SkeletonBlogpost from '@pf/src/modules/icons/skeletons/SkeletonBlogpost.vue'\nimport Publics from '@pf/src/modules/organizations/components/sections/Publics.vue'\nimport Comments from '@pf/src/modules/community/components/sections/Comments.vue';\nimport Viewer from '@pf/src/modules/constructor/components/sections/Viewer.vue';\nimport * as blog from '@pf/src/modules/community/store/blogposts.js';\nimport * as auth from '@pf/src/modules/auth/views/store/auth';\n \nimport { useRoute } from 'vue-router';\n\nconst route = useRoute();\nconst blogpost = computed(() => blog.state.current);\nconst isLoading = ref(false);\nconst canShare = ref(false);\nconst error = ref(null);\n\nasync function fetchBlogpost() {\n try {\n isLoading.value = true;\n const data = await blog.read({ user: auth.state.user?._id, url: route.params.url });\n blogpost.value = data[0];\n // Обновляем состояние хранилища\n blog.state.current = data[0];\n } catch (err) {\n error.value = err;\n console.error('Error fetching blogpost:', err);\n } finally {\n isLoading.value = false;\n }\n}\n\nonServerPrefetch(async() => {\n\tawait fetchBlogpost()\n});\n\nonMounted(async() => {\n if (!blogpost.value || blogpost.value.url !== route.params.url) {\n await fetchBlogpost();\n }\n canShare.value = !!navigator.share;\n});\n\n\nconst share = async () => {\n if (!canShare.value) return;\n try {\n await navigator.share({\n title: blogpost.value.name,\n text: firstText.value?.content.slice(0, 120) || 'Check out this blog post!',\n url: window.location.href,\n });\n console.log('Content shared successfully');\n } catch (error) {\n console.error('Error sharing:', error);\n }\n};\n\nconst firstImage = computed(() => {\n return blogpost.value?.content?.find(block => block.type === 'ImageUpload');\n});\n\nconst firstText = computed(() => {\n return blogpost.value?.content?.find(block => \n block.type === 'Textarea' && block.class !== 'h2'\n );\n});\n\nconst metadata = computed(() => ({\n title: blogpost.value?.name,\n description: firstText.value?.content.slice(0, 120),\n meta: [\n { hid: 'description', name: 'description', content: firstText.value?.content.slice(0, 120) },\n { hid: 'og:title', property: 'og:title', content: blogpost.value?.name },\n { hid: 'og:description', property: 'og:description', content: firstText.value?.content.slice(0, 120) },\n { hid: 'og:image', property: 'og:image', content: firstImage.value?.content ? `${process.env.FILE_SERVER_URL}${firstImage.value.content}` : `${process.env.FILE_SERVER_URL}/favicon/cover.jpg` },\n { hid: 'twitter:title', name: 'twitter:title', content: blogpost.value?.name },\n { hid: 'twitter:description', name: 'twitter:description', content: firstText.value?.content.slice(0, 120) },\n { hid: 'twitter:image', name: 'twitter:image', content: firstImage.value?.content ? `${process.env.FILE_SERVER_URL}${firstImage.value.content}` : `${process.env.FILE_SERVER_URL}/favicon/cover.jpg` },\n { hid: 'twitter:card', name: 'twitter:card', content: 'summary_large_image' },\n ],\n}));\n\nuseHead(metadata);\n</script>\n\n<style lang=\"scss\">\n\n</style>\n"],"names":["useRoute","computed","blog.state","ref","blog.read","auth.state","onServerPrefetch","onMounted","useHead"],"mappings":";;;;;;;;;;;;;;;;;;;;;;AA8EA,UAAM,QAAQA,UAAQ,SAAA;AACtB,UAAM,WAAWC,IAAQ,SAAC,MAAMC,UAAU,MAAC,OAAO;AAClD,UAAM,YAAYC,IAAAA,IAAI,KAAK;AAC3B,UAAM,WAAWA,IAAAA,IAAI,KAAK;AAC1B,UAAM,QAAQA,IAAAA,IAAI,IAAI;AAEtB,mBAAe,gBAAgB;;AAC7B,UAAI;AACF,kBAAU,QAAQ;AAClB,cAAM,OAAO,MAAMC,UAAAA,KAAU,EAAE,OAAMC,UAAAA,MAAW,SAAXA,mBAAiB,KAAK,KAAK,MAAM,OAAO,IAAK,CAAA;AAClF,iBAAS,QAAQ,KAAK,CAAC;AAEvBH,kBAAAA,MAAW,UAAU,KAAK,CAAC;AAAA,MAC5B,SAAQ,KAAK;AACZ,cAAM,QAAQ;AACd,gBAAQ,MAAM,4BAA4B,GAAG;AAAA,MACjD,UAAY;AACR,kBAAU,QAAQ;AAAA,MACnB;AAAA,IACH;AAEAI,QAAAA,iBAAiB,YAAW;AAC3B,YAAM,cAAe;AAAA,IACtB,CAAC;AAEDC,QAAAA,UAAU,YAAW;AACnB,UAAI,CAAC,SAAS,SAAS,SAAS,MAAM,QAAQ,MAAM,OAAO,KAAK;AAC9D,cAAM,cAAa;AAAA,MACpB;AACD,eAAS,QAAQ,CAAC,CAAC,UAAU;AAAA,IAC/B,CAAC;AAiBD,UAAM,aAAaN,IAAQ,SAAC,MAAM;;AAChC,cAAO,oBAAS,UAAT,mBAAgB,YAAhB,mBAAyB,KAAK,WAAS,MAAM,SAAS;AAAA,IAC/D,CAAC;AAED,UAAM,YAAYA,IAAQ,SAAC,MAAM;;AAC/B,cAAO,oBAAS,UAAT,mBAAgB,YAAhB,mBAAyB;AAAA,QAAK,WACnC,MAAM,SAAS,cAAc,MAAM,UAAU;AAAA;AAAA,IAEjD,CAAC;AAED,UAAM,WAAWA,IAAQ,SAAC,MAAO;;AAAA;AAAA,QAC/B,QAAO,cAAS,UAAT,mBAAgB;AAAA,QACvB,cAAa,eAAU,UAAV,mBAAiB,QAAQ,MAAM,GAAG;AAAA,QAC/C,MAAM;AAAA,UACJ,EAAE,KAAK,eAAe,MAAM,eAAe,UAAS,eAAU,UAAV,mBAAiB,QAAQ,MAAM,GAAG,KAAM;AAAA,UAC5F,EAAE,KAAK,YAAY,UAAU,YAAY,UAAS,cAAS,UAAT,mBAAgB,KAAM;AAAA,UACxE,EAAE,KAAK,kBAAkB,UAAU,kBAAkB,UAAS,eAAU,UAAV,mBAAiB,QAAQ,MAAM,GAAG,KAAM;AAAA,UACtG,EAAE,KAAK,YAAY,UAAU,YAAY,WAAS,gBAAW,UAAX,mBAAkB,WAAU,GAAG,QAAQ,IAAI,eAAe,GAAG,WAAW,MAAM,OAAO,KAAK,GAAG,QAAQ,IAAI,eAAe,qBAAsB;AAAA,UAChM,EAAE,KAAK,iBAAiB,MAAM,iBAAiB,UAAS,cAAS,UAAT,mBAAgB,KAAM;AAAA,UAC9E,EAAE,KAAK,uBAAuB,MAAM,uBAAuB,UAAS,eAAU,UAAV,mBAAiB,QAAQ,MAAM,GAAG,KAAM;AAAA,UAC5G,EAAE,KAAK,iBAAiB,MAAM,iBAAiB,WAAS,gBAAW,UAAX,mBAAkB,WAAU,GAAG,QAAQ,IAAI,eAAe,GAAG,WAAW,MAAM,OAAO,KAAK,GAAG,QAAQ,IAAI,eAAe,qBAAsB;AAAA,UACtM,EAAE,KAAK,gBAAgB,MAAM,gBAAgB,SAAS,sBAAuB;AAAA,QAC9E;AAAA,MACH;AAAA,KAAE;AAEFO,iBAAO,EAAC,QAAQ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}