@mframework/layer-commerce 0.0.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (355) hide show
  1. package/README.md +101 -0
  2. package/app/cart/useCart.ts +1 -0
  3. package/app/components/ChevronIcon/ChevronIcon.config.ts +17 -0
  4. package/app/components/DateSelect/DateSelect.config.ts +15 -0
  5. package/app/components/Field/Field.config.ts +14 -0
  6. package/app/components/FieldDate/FieldDate.config.ts +16 -0
  7. package/app/components/Form/Form.type.ts +8 -0
  8. package/app/components/Product/Product.config.ts +19 -0
  9. package/app/components/Product/Stock.config.ts +15 -0
  10. package/app/components/ProductCustomizableOption/ProductCustomizableOption.config.ts +5 -0
  11. package/app/components/ProductGallery/ProductGallery.config.ts +15 -0
  12. package/app/components/ProductReviews/ProductReviews.config.ts +8 -0
  13. package/app/composables/_types.ts +18 -0
  14. package/app/composables/adapters/abstract/cartAdapter.ts +0 -0
  15. package/app/composables/adapters/abstract/categoryAdapter.ts +0 -0
  16. package/app/composables/adapters/abstract/customerAdapter.ts +0 -0
  17. package/app/composables/adapters/abstract/inventoryAdapter.ts +0 -0
  18. package/app/composables/adapters/abstract/orderAdapter.ts +0 -0
  19. package/app/composables/adapters/abstract/productAdapter.ts +7 -0
  20. package/app/composables/cart/registry.ts +20 -0
  21. package/app/composables/cart/types.ts +18 -0
  22. package/app/composables/cart/useCart.ts +15 -0
  23. package/app/composables/config.ts +19 -0
  24. package/app/composables/defs/apiDefinitions.ts +55 -0
  25. package/app/composables/defs/extension.feature +40 -0
  26. package/app/composables/defs/extension.mocks.ts +39 -0
  27. package/app/composables/defs/extension.test.ts +280 -0
  28. package/app/composables/defs/extension.ts +236 -0
  29. package/app/composables/defs/index.ts +3 -0
  30. package/app/composables/defs/typeHelpers.ts +8 -0
  31. package/app/composables/defs/types.ts +136 -0
  32. package/app/composables/domain/product.ts +12 -0
  33. package/app/composables/featured-products.ts +20 -0
  34. package/app/composables/helpers/contextualizedNormalizers.feature +14 -0
  35. package/app/composables/helpers/contextualizedNormalizers.test.ts +85 -0
  36. package/app/composables/helpers/contextualizedNormalizers.ts +20 -0
  37. package/app/composables/helpers/index.ts +1 -0
  38. package/app/composables/index.ts +9 -0
  39. package/app/composables/methods/auth.ts +83 -0
  40. package/app/composables/methods/cart.ts +119 -0
  41. package/app/composables/methods/category.ts +27 -0
  42. package/app/composables/methods/checkout.ts +54 -0
  43. package/app/composables/methods/customer.ts +52 -0
  44. package/app/composables/methods/helpers.ts +5 -0
  45. package/app/composables/methods/index.ts +75 -0
  46. package/app/composables/methods/order.ts +39 -0
  47. package/app/composables/methods/product.ts +95 -0
  48. package/app/composables/methods/settings.ts +16 -0
  49. package/app/composables/models/cart.ts +95 -0
  50. package/app/composables/models/category.ts +13 -0
  51. package/app/composables/models/checkout.ts +17 -0
  52. package/app/composables/models/customer.ts +16 -0
  53. package/app/composables/models/facets.ts +25 -0
  54. package/app/composables/models/index.ts +94 -0
  55. package/app/composables/models/order.ts +43 -0
  56. package/app/composables/models/product.ts +73 -0
  57. package/app/composables/models/shared.ts +75 -0
  58. package/app/composables/orders.ts +69 -0
  59. package/app/composables/products/registry.ts +86 -0
  60. package/app/composables/products/types.ts +8 -0
  61. package/app/composables/products/useEvents.ts +26 -0
  62. package/app/composables/products/useGiftCards.ts +29 -0
  63. package/app/composables/products/useProducts.ts +12 -0
  64. package/app/composables/products/useSubscriptions.ts +29 -0
  65. package/app/composables/products.ts +30 -0
  66. package/app/composables/registry.ts +24 -0
  67. package/app/composables/useAuth.ts +43 -0
  68. package/app/composables/useBreakpoints/index.ts +1 -0
  69. package/app/composables/useBreakpoints/useBreakpoints.ts +28 -0
  70. package/app/composables/useCache.ts +38 -0
  71. package/app/composables/useCart/__tests__/useCart.spec.ts +11 -0
  72. package/app/composables/useCart/index.ts +1 -0
  73. package/app/composables/useCart/types.ts +17 -0
  74. package/app/composables/useCart/useCart.ts +46 -0
  75. package/app/composables/useCartShippingMethods/__tests__/useCartShippingMethods.spec.ts +11 -0
  76. package/app/composables/useCartShippingMethods/index.ts +1 -0
  77. package/app/composables/useCartShippingMethods/types.ts +17 -0
  78. package/app/composables/useCartShippingMethods/useCartShippingMethods.ts +47 -0
  79. package/app/composables/useCatalog.ts +26 -0
  80. package/app/composables/useContent.ts +26 -0
  81. package/app/composables/useCustomer/__tests__/useCustomer.spec.ts +25 -0
  82. package/app/composables/useCustomer/index.ts +2 -0
  83. package/app/composables/useCustomer/types.ts +17 -0
  84. package/app/composables/useCustomer/useCustomer.ts +40 -0
  85. package/app/composables/useCustomerAddress/__tests__/useCustomerAddress.spec.ts +11 -0
  86. package/app/composables/useCustomerAddress/index.ts +2 -0
  87. package/app/composables/useCustomerAddress/types.ts +17 -0
  88. package/app/composables/useCustomerAddress/useCustomerAddress.ts +55 -0
  89. package/app/composables/useCustomerOrder/__tests__/useCustomerOrder.spec.ts +11 -0
  90. package/app/composables/useCustomerOrder/adress.ts +10 -0
  91. package/app/composables/useCustomerOrder/index.ts +2 -0
  92. package/app/composables/useCustomerOrder/product.ts +37 -0
  93. package/app/composables/useCustomerOrder/types.ts +40 -0
  94. package/app/composables/useCustomerOrder/useCustomerOrder.ts +63 -0
  95. package/app/composables/useCustomerOrders/__tests__/useCustomerOrders.spec.ts +11 -0
  96. package/app/composables/useCustomerOrders/index.ts +2 -0
  97. package/app/composables/useCustomerOrders/types.ts +20 -0
  98. package/app/composables/useCustomerOrders/useCustomerOrders.ts +56 -0
  99. package/app/composables/useCustomerReturns/__tests__/useCustomerReturns.spec.ts +11 -0
  100. package/app/composables/useCustomerReturns/index.ts +2 -0
  101. package/app/composables/useCustomerReturns/types.ts +17 -0
  102. package/app/composables/useCustomerReturns/useCustomerReturns.ts +41 -0
  103. package/app/composables/useHandleError/index.ts +1 -0
  104. package/app/composables/useHandleError/types.ts +11 -0
  105. package/app/composables/useHandleError/useHandleError.ts +27 -0
  106. package/app/composables/useInventory.ts +29 -0
  107. package/app/composables/useLoading.ts +21 -0
  108. package/app/composables/useNotification.ts +21 -0
  109. package/app/composables/usePageTitle.ts +20 -0
  110. package/app/composables/useProduct/index.ts +2 -0
  111. package/app/composables/useProduct/types.ts +17 -0
  112. package/app/composables/useProduct/useProduct.ts +42 -0
  113. package/app/composables/useProductAttribute/__tests__/useProduct.mock.ts +31 -0
  114. package/app/composables/useProductAttribute/__tests__/useProductAttribute.spec.ts +14 -0
  115. package/app/composables/useProductAttribute/index.ts +1 -0
  116. package/app/composables/useProductAttribute/useProductAttribute.ts +37 -0
  117. package/app/composables/useProductRecommended/__tests__/useProductRecommended.spec.ts +12 -0
  118. package/app/composables/useProductRecommended/index.ts +1 -0
  119. package/app/composables/useProductRecommended/types.ts +17 -0
  120. package/app/composables/useProductRecommended/useProductRecommended.ts +43 -0
  121. package/app/composables/useProductReviews/__tests__/productReviews.mock.ts +20 -0
  122. package/app/composables/useProductReviews/__tests__/useProductReviews.spec.ts +22 -0
  123. package/app/composables/useProductReviews/index.ts +2 -0
  124. package/app/composables/useProductReviews/types.ts +17 -0
  125. package/app/composables/useProductReviews/useProductReviews.ts +46 -0
  126. package/app/composables/useProducts/__tests__/useProducts.spec.ts +11 -0
  127. package/app/composables/useProducts/types.ts +22 -0
  128. package/app/composables/useProducts/useProducts.ts +41 -0
  129. package/app/composables/useTax.ts +27 -0
  130. package/app/composables/validationRules/index.ts +1 -0
  131. package/app/composables/validationRules/password.feature +67 -0
  132. package/app/composables/validationRules/password.test.ts +89 -0
  133. package/app/composables/validationRules/password.ts +25 -0
  134. package/app/normalizers/Cart.query.ts +729 -0
  135. package/app/normalizers/Cart.type.ts +285 -0
  136. package/app/normalizers/Category.query.ts +146 -0
  137. package/app/normalizers/Category.type.ts +55 -0
  138. package/app/normalizers/CheckEmail.query.ts +28 -0
  139. package/app/normalizers/Checkout.query.ts +253 -0
  140. package/app/normalizers/Checkout.type.ts +77 -0
  141. package/app/normalizers/CmsBlock.query.ts +57 -0
  142. package/app/normalizers/CmsBlock.type.ts +25 -0
  143. package/app/normalizers/CmsPage.query.ts +59 -0
  144. package/app/normalizers/CmsPage.type.ts +26 -0
  145. package/app/normalizers/Config.query.ts +224 -0
  146. package/app/normalizers/Config.type.ts +196 -0
  147. package/app/normalizers/ContactForm.query.ts +49 -0
  148. package/app/normalizers/CreditMemo.type.ts +49 -0
  149. package/app/normalizers/GiftCard.type.ts +24 -0
  150. package/app/normalizers/Invoice.type.ts +58 -0
  151. package/app/normalizers/Menu.query.ts +54 -0
  152. package/app/normalizers/Menu.type.ts +22 -0
  153. package/app/normalizers/MyAccount.query.ts +268 -0
  154. package/app/normalizers/MyAccount.type.ts +129 -0
  155. package/app/normalizers/NewsletterSubscription.query.ts +38 -0
  156. package/app/normalizers/Order.query.ts +741 -0
  157. package/app/normalizers/Order.type.ts +268 -0
  158. package/app/normalizers/Payment.type.ts +28 -0
  159. package/app/normalizers/ProductAlerts.query.ts +23 -0
  160. package/app/normalizers/ProductCompare.query.ts +226 -0
  161. package/app/normalizers/ProductCompare.type.ts +90 -0
  162. package/app/normalizers/ProductList.query.ts +1620 -0
  163. package/app/normalizers/ProductList.type.ts +726 -0
  164. package/app/normalizers/Region.query.ts +58 -0
  165. package/app/normalizers/Region.type.ts +23 -0
  166. package/app/normalizers/Return.type.ts +50 -0
  167. package/app/normalizers/Review.query.ts +81 -0
  168. package/app/normalizers/Review.type.ts +42 -0
  169. package/app/normalizers/Slider.query.ts +72 -0
  170. package/app/normalizers/Slider.type.ts +26 -0
  171. package/app/normalizers/StoreInPickUp.query.ts +54 -0
  172. package/app/normalizers/StoreInPickUp.type.ts +59 -0
  173. package/app/normalizers/Subscription.type.ts +25 -0
  174. package/app/normalizers/Transaction.type.ts +20 -0
  175. package/app/normalizers/UrlRewrites.query.ts +55 -0
  176. package/app/normalizers/UrlRewrites.type.ts +25 -0
  177. package/app/normalizers/Wishlist.query.ts +202 -0
  178. package/app/normalizers/Wishlist.type.ts +42 -0
  179. package/app/pages/brand/[...slug].vue +76 -0
  180. package/app/pages/brands.vue +67 -0
  181. package/app/pages/cart.vue +142 -0
  182. package/app/pages/compare.vue +166 -0
  183. package/app/pages/departments/[...slug].vue +353 -0
  184. package/app/pages/departments/category/[...slug].vue +114 -0
  185. package/app/pages/incentive/[...id].vue +66 -0
  186. package/app/pages/invoice/[id].vue +309 -0
  187. package/app/pages/order/[id].vue +327 -0
  188. package/app/pages/product/[...id].vue +309 -0
  189. package/app/pages/product/showcases/index.vue +86 -0
  190. package/app/pages/shipment/[...id].vue +176 -0
  191. package/app/pages/shop/[...slug].vue +158 -0
  192. package/app/pages/shops.vue +76 -0
  193. package/app/pages/subscription/[...id].vue +147 -0
  194. package/app/pages/transaction/[...id].vue +74 -0
  195. package/app/routes/CategoryPage/CategoryPage.config.ts +28 -0
  196. package/app/routes/CategoryPage/CategoryPage.type.ts +8 -0
  197. package/app/routes/Checkout/Checkout.config.ts +3 -0
  198. package/app/routes/Checkout/Checkout.type.ts +14 -0
  199. package/app/routes/MyAccount/MyAccount.config.ts +1 -0
  200. package/app/routes/SearchPage/SearchPage.config.ts +1 -0
  201. package/app/routes/UrlRewrites/UrlRewrites.config.ts +5 -0
  202. package/app/stores/Cart/Cart.type.ts +26 -0
  203. package/app/stores/MyAccount/MyAccount.action.ts +7 -0
  204. package/app/stores/Notification/Notification.action.ts +40 -0
  205. package/app/stores/Notification/Notification.type.ts +16 -0
  206. package/app/stores/Popup/Popup.action.ts +30 -0
  207. package/app/stores/Product/Product.dispatcher.ts +53 -0
  208. package/app/stores/Product/Product.reducer.ts +12 -0
  209. package/app/stores/ProductList/ProductList.dispatcher.ts +35 -0
  210. package/app/stores/ProductList/ProductList.reducer.ts +13 -0
  211. package/app/stores/Store.type.ts +31 -0
  212. package/app/stores/Wishlist/Wishlist.type.ts +12 -0
  213. package/app/stores/cart.ts +218 -0
  214. package/app/stores/cartStore.ts +224 -0
  215. package/app/stores/checkout.ts +18 -0
  216. package/app/stores/compare.ts +65 -0
  217. package/app/stores/currency.js +29 -0
  218. package/app/stores/digital-products.js +11 -0
  219. package/app/stores/orders.ts +172 -0
  220. package/app/stores/product.ts +34 -0
  221. package/app/stores/productList.ts +35 -0
  222. package/app/stores/productListInfo.ts +0 -0
  223. package/app/stores/products.ts +118 -0
  224. package/app/stores/recentlyViewedProducts.ts +56 -0
  225. package/app/stores/review.ts +33 -0
  226. package/app/stores/storeInPickUp.ts +21 -0
  227. package/app/stores/user.ts +20 -0
  228. package/app/stores/wishlist.ts +46 -0
  229. package/app/types/Account.type.ts +141 -0
  230. package/app/types/Breadcrumbs.type.ts +23 -0
  231. package/app/types/CMS.type.ts +33 -0
  232. package/app/types/Category.type.ts +67 -0
  233. package/app/types/Checkout.type.ts +58 -0
  234. package/app/types/Common.type.ts +77 -0
  235. package/app/types/Config.type.ts +47 -0
  236. package/app/types/Device.type.ts +37 -0
  237. package/app/types/Direction.type.ts +23 -0
  238. package/app/types/Downloadable.type.ts +24 -0
  239. package/app/types/Error.type.ts +22 -0
  240. package/app/types/Field.type.ts +151 -0
  241. package/app/types/Global.type.ts +156 -0
  242. package/app/types/Graphql.type.ts +4497 -0
  243. package/app/types/Layout.type.ts +18 -0
  244. package/app/types/Menu.type.ts +39 -0
  245. package/app/types/MiniCart.type.ts +61 -0
  246. package/app/types/NotificationList.type.ts +34 -0
  247. package/app/types/Order.type.ts +174 -0
  248. package/app/types/Price.type.ts +72 -0
  249. package/app/types/ProductCompare.type.ts +24 -0
  250. package/app/types/ProductList.type.ts +351 -0
  251. package/app/types/Rating.type.ts +42 -0
  252. package/app/types/Router.type.ts +67 -0
  253. package/app/types/Slider.type.ts +25 -0
  254. package/app/types/StockStatus.type.ts +21 -0
  255. package/app/types/domain/index.ts +94 -0
  256. package/app/types/index.ts +33 -0
  257. package/app/types/shims.d.ts +52 -0
  258. package/app/types/tilework-opus.d.ts +48 -0
  259. package/app/utils/Address/Address.type.ts +28 -0
  260. package/app/utils/Address/index.ts +325 -0
  261. package/app/utils/Auth/IsSignedIn.ts +4 -0
  262. package/app/utils/Auth/Token.ts +9 -0
  263. package/app/utils/Base64/Base64.ts +16 -0
  264. package/app/utils/Base64/index.ts +12 -0
  265. package/app/utils/Browser/Browser.ts +29 -0
  266. package/app/utils/Browser/index.ts +12 -0
  267. package/app/utils/BrowserDatabase/BrowserDatabase.ts +70 -0
  268. package/app/utils/BrowserDatabase/index.ts +12 -0
  269. package/app/utils/CSS/CSS.ts +65 -0
  270. package/app/utils/CSS/index.ts +12 -0
  271. package/app/utils/Cache/Cache.ts +99 -0
  272. package/app/utils/Cart/Cart.ts +300 -0
  273. package/app/utils/Cart/Cart.type.ts +76 -0
  274. package/app/utils/Cart/Token.ts +59 -0
  275. package/app/utils/Cart/index.ts +13 -0
  276. package/app/utils/Category/Filters.ts +39 -0
  277. package/app/utils/Category/index.ts +12 -0
  278. package/app/utils/Common/index.ts +32 -0
  279. package/app/utils/Compare/Compare.ts +89 -0
  280. package/app/utils/Compare/index.ts +12 -0
  281. package/app/utils/Currency/Currency.ts +84 -0
  282. package/app/utils/Currency/index.ts +12 -0
  283. package/app/utils/DynamicReducer/DynamicReducer.type.ts +14 -0
  284. package/app/utils/DynamicReducer/Helper.ts +30 -0
  285. package/app/utils/DynamicReducer/index.tsx +35 -0
  286. package/app/utils/ElementTransition/ElementTransition.ts +100 -0
  287. package/app/utils/Form/Extract.ts +316 -0
  288. package/app/utils/Form/Form.ts +46 -0
  289. package/app/utils/Form/Form.type.ts +60 -0
  290. package/app/utils/Form/Transform.ts +33 -0
  291. package/app/utils/FormPortalCollector/index.ts +45 -0
  292. package/app/utils/History/History.type.ts +31 -0
  293. package/app/utils/History/index.ts +17 -0
  294. package/app/utils/Manipulations/Array.ts +18 -0
  295. package/app/utils/Manipulations/Date.ts +36 -0
  296. package/app/utils/Manipulations/index.ts +14 -0
  297. package/app/utils/Media/Media.ts +27 -0
  298. package/app/utils/Media/index.ts +13 -0
  299. package/app/utils/Menu/Menu.ts +116 -0
  300. package/app/utils/Menu/Menu.type.ts +37 -0
  301. package/app/utils/Menu/index.ts +12 -0
  302. package/app/utils/Mobile/index.ts +13 -0
  303. package/app/utils/Mobile/isMobile.ts +34 -0
  304. package/app/utils/Orders/Orders.ts +71 -0
  305. package/app/utils/Orders/Orders.type.ts +19 -0
  306. package/app/utils/Orders/index.ts +13 -0
  307. package/app/utils/Polyfill/index.ts +336 -0
  308. package/app/utils/Preload/CategoryPreload.ts +74 -0
  309. package/app/utils/Preload/ProductPreload.ts +28 -0
  310. package/app/utils/Preload/index.ts +75 -0
  311. package/app/utils/Price/Price.config.ts +189 -0
  312. package/app/utils/Price/Price.ts +63 -0
  313. package/app/utils/Price/index.ts +12 -0
  314. package/app/utils/Product/Extract.ts +652 -0
  315. package/app/utils/Product/Product.ts +575 -0
  316. package/app/utils/Product/Product.type.ts +260 -0
  317. package/app/utils/Product/Transform.ts +382 -0
  318. package/app/utils/Product/index.ts +12 -0
  319. package/app/utils/Promise/MakeCancelable.ts +44 -0
  320. package/app/utils/Promise/Promise.type.ts +15 -0
  321. package/app/utils/Promise/index.ts +13 -0
  322. package/app/utils/Query/Field.ts +71 -0
  323. package/app/utils/Query/Fragment.ts +22 -0
  324. package/app/utils/Query/PrepareDocument.ts +119 -0
  325. package/app/utils/Query/Query.type.ts +26 -0
  326. package/app/utils/Query/index.ts +15 -0
  327. package/app/utils/Request/Config.ts +21 -0
  328. package/app/utils/Request/DataContainer.ts +102 -0
  329. package/app/utils/Request/Debounce.ts +48 -0
  330. package/app/utils/Request/Error.ts +31 -0
  331. package/app/utils/Request/Hash.ts +88 -0
  332. package/app/utils/Request/LowPriorityLoad.ts +32 -0
  333. package/app/utils/Request/LowPriorityRender.ts +55 -0
  334. package/app/utils/Request/Mutation.ts +25 -0
  335. package/app/utils/Request/Query.ts +25 -0
  336. package/app/utils/Request/QueryDispatcher.ts +135 -0
  337. package/app/utils/Request/Request.ts +310 -0
  338. package/app/utils/Store/Store.type.ts +26 -0
  339. package/app/utils/Store/index.ts +71 -0
  340. package/app/utils/Url/Url.ts +297 -0
  341. package/app/utils/Url/index.ts +12 -0
  342. package/app/utils/Validator/Config.ts +96 -0
  343. package/app/utils/Validator/Validator.ts +268 -0
  344. package/app/utils/Validator/Validator.type.ts +47 -0
  345. package/app/utils/Validator/index.ts +12 -0
  346. package/app/utils/Wishlist/Wishlist.ts +65 -0
  347. package/app/utils/Wishlist/index.ts +12 -0
  348. package/app/utils/client.ts +280 -0
  349. package/app/utils/index.ts +53 -0
  350. package/app/utils/normalizer.ts +23 -0
  351. package/app/utils/normalizers/magento.ts +29 -0
  352. package/app/utils/normalizers/shopify.ts +29 -0
  353. package/nuxt.config.ts +11 -0
  354. package/package.json +43 -0
  355. package/tsconfig.json +45 -0
@@ -0,0 +1,353 @@
1
+ <template>
2
+ <div>
3
+ <div v-if="department?.name === 'Deals'">
4
+ <v-toolbar :style="`background-color: ${department?.color}; color: ${department?.colortext}`"
5
+ :title="department?.name"></v-toolbar>
6
+ <deals :category="department?.id" />
7
+ </div>
8
+
9
+ <div v-else>
10
+ <v-card variant="text">
11
+ <v-toolbar :style="`background-color: ${department?.color}; color: ${department?.colortext}`"
12
+ :title="department?.name">
13
+ <v-slide-group show-arrows v-if="department?.categories?.length">
14
+ <v-slide-group-item v-slot="{ isSelected, toggle }">
15
+ <v-menu>
16
+ <template v-slot:activator="{ props }">
17
+ <v-btn :color="isSelected ? 'primary' : undefined" class="ma-2" @click="toggle"
18
+ v-bind="props" append-icon="fas:fa fa-caret-down" variant="text">
19
+ Categories
20
+ </v-btn>
21
+ </template>
22
+ <v-list class="departmentMenu">
23
+ <v-row>
24
+ <v-col cols="3" v-for="categories in department?.categories"
25
+ :key="categories?.id">
26
+ <v-list-item>
27
+ <v-chip><NuxtLink
28
+ :to="`/departments/category/${categories?.categories_id?.slug}`">
29
+ {{ categories?.categories_id?.name }}</NuxtLink></v-chip>
30
+ </v-list-item>
31
+ </v-col>
32
+ </v-row>
33
+ </v-list>
34
+ </v-menu>
35
+ </v-slide-group-item>
36
+
37
+ <v-slide-group-item v-if="department?.menus?.length" v-for="menu in department?.menus"
38
+ :key="menu" v-slot="{ isSelected, toggle }">
39
+ <v-btn :color="isSelected ? 'primary' : undefined" class="ma-2" @click="toggle"
40
+ :href="`${menu?.url}`">
41
+ {{ menu?.name }}
42
+ </v-btn>
43
+ </v-slide-group-item>
44
+ </v-slide-group>
45
+ </v-toolbar>
46
+
47
+ <!--Department Top Banner Section-->
48
+ <section data-bs-version="5.1" class="pricing6 shopm5 cid-tZY31Y2JxZ" id="apricing6-6g">
49
+
50
+ <div class="mbr-overlay"></div>
51
+ <div class="container-fluid">
52
+ <div class="row align-items-stretch items-row justify-content-center">
53
+
54
+ <div class="col-lg-6">
55
+ <div v-if="department?.name === 'Travel'">
56
+ <travel :category="department?.name" />
57
+ </div>
58
+ <!--<div v-else-if="department?.name === 'Appstore'">
59
+ <appstore :category="department?.name" />
60
+ </div>-->
61
+ <div v-else-if="department?.name === 'Weather'">
62
+ <weather :category="department?.name" />
63
+ </div>
64
+
65
+ <div v-else-if="department?.name === 'Time'">
66
+ <timeComponent :category="department?.name" />
67
+ </div>
68
+
69
+ <div v-else class="mbr-section-head" :style="`background-color: ${department?.color}`">
70
+ <h4 class="mbr-section-title mbr-fonts-style mb-0 display-7"
71
+ :style="`color: ${department?.colortext}`">
72
+ <strong>Meeovi</strong>
73
+ </h4>
74
+ <h5 class="mbr-section-subtitle mbr-fonts-style mb-0 display-2"
75
+ :style="`color: ${department?.colortext}`">
76
+ <strong>{{ department?.name }}</strong>
77
+ </h5>
78
+ <h5 class="main-text mbr-fonts-style mb-0 display-7"
79
+ :style="`color: ${department?.colortext}`">
80
+ {{ department?.description }}
81
+ </h5>
82
+ </div>
83
+ </div>
84
+
85
+ <v-sheet
86
+ class="mx-auto col-lg-6" style="background-color: transparent; box-shadow: none;">
87
+ <h4 style="left: 15px; position: relative;">{{ callouts?.menus?.[1]?.name }}</h4>
88
+ <v-slide-group v-model="model" class="pa-4" selected-class="bg-success" show-arrows>
89
+ <v-slide-group-item v-slot="{ isSelected, toggle, selectedClass }"
90
+ v-for="products in department?.products" :key="products">
91
+ <productCard :product="products?.products_id" :class="['ma-4', selectedClass]"
92
+ @click="toggle" />
93
+ <div class="d-flex fill-height align-center justify-center">
94
+ <v-scale-transition>
95
+ <v-icon v-if="isSelected" color="white" icon="mdi-close-circle-outline"
96
+ size="48"></v-icon>
97
+ </v-scale-transition>
98
+ </div>
99
+ </v-slide-group-item>
100
+ </v-slide-group>
101
+ </v-sheet>
102
+ </div>
103
+ </div>
104
+ </section>
105
+
106
+ <!--Department Content Section-->
107
+ <section data-bs-version="5.1" class="gallery2 shopm5 cid-uW1BojE78S" id="agallery2-0" v-if="department?.shorts?.length && department?.products?.products_id?.type === 'department'"
108
+ :style="`background-image: url(${getAssetUrl(department?.image)})`">
109
+ <div class="mbr-overlay" style="opacity: 0.8; background-color: rgb(255, 255, 255);">
110
+ </div>
111
+
112
+ <div class="container-fluid">
113
+ <div class="row">
114
+ <!--Vibez Slider-->
115
+ <v-sheet
116
+ class="mx-auto sliderProducts row align-items-stretch items-row justify-content-center">
117
+ <v-slide-group v-model="model" class="pa-4" selected-class="bg-success" show-arrows>
118
+ <v-slide-group-item v-slot="{ isSelected, toggle, selectedClass }"
119
+ v-for="shorts in department?.shorts" :key="shorts">
120
+ <shorts :short="shorts?.shorts_id" :class="['ma-4', selectedClass]"
121
+ @click="toggle" />
122
+ <div class="d-flex fill-height align-center justify-center">
123
+ <v-scale-transition>
124
+ <v-icon v-if="isSelected" color="white" icon="mdi-close-circle-outline"
125
+ size="48"></v-icon>
126
+ </v-scale-transition>
127
+ </div>
128
+ </v-slide-group-item>
129
+ </v-slide-group>
130
+ </v-sheet>
131
+ </div>
132
+ </div>
133
+ </section>
134
+
135
+ <v-row class="departmentRow">
136
+ <!--Best Seller Product Slider-->
137
+ <v-sheet class="mx-auto sliderProducts row align-items-stretch items-row justify-content-center">
138
+ <h4 style="left: 15px; position: relative;">{{ callouts?.menus?.[1]?.name }}</h4>
139
+ <v-slide-group v-model="model" class="pa-4" selected-class="bg-success" show-arrows>
140
+ <v-slide-group-item v-slot="{ isSelected, toggle, selectedClass }"
141
+ v-for="products in best?.products" :key="products">
142
+ <productCard :product="products?.products_id" :class="['ma-4', selectedClass]"
143
+ @click="toggle" />
144
+ <div class="d-flex fill-height align-center justify-center">
145
+ <v-scale-transition>
146
+ <v-icon v-if="isSelected" color="white" icon="mdi-close-circle-outline"
147
+ size="48"></v-icon>
148
+ </v-scale-transition>
149
+ </div>
150
+ </v-slide-group-item>
151
+ </v-slide-group>
152
+ </v-sheet>
153
+
154
+ <!--List of latest products in the department-->
155
+ <v-sheet class="mx-auto sliderProducts row align-items-stretch items-row justify-content-center">
156
+ <h4 style="left: 15px; position: relative;">{{ callouts?.menus?.[2]?.name }}</h4>
157
+ <v-slide-group v-model="model" class="pa-4" selected-class="bg-success" show-arrows>
158
+ <v-slide-group-item v-slot="{ isSelected, toggle, selectedClass }"
159
+ v-for="products in latestProducts?.products" :key="products">
160
+ <productCard :product="products?.products_id" :class="['ma-4', selectedClass]"
161
+ @click="toggle" />
162
+ <div class="d-flex fill-height align-center justify-center">
163
+ <v-scale-transition>
164
+ <v-icon v-if="isSelected" color="white" icon="mdi-close-circle-outline"
165
+ size="48"></v-icon>
166
+ </v-scale-transition>
167
+ </div>
168
+ </v-slide-group-item>
169
+ </v-slide-group>
170
+ </v-sheet>
171
+
172
+ <!--List of products in the department-->
173
+ <v-sheet class="mx-auto sliderProducts row align-items-stretch items-row justify-content-center">
174
+ <v-slide-group v-model="model" class="pa-4" selected-class="bg-success" show-arrows>
175
+ <v-slide-group-item v-slot="{ isSelected, toggle, selectedClass }"
176
+ v-for="products in department?.products" :key="products">
177
+ <productCard :product="products?.products_id" :class="['ma-4', selectedClass]"
178
+ @click="toggle" />
179
+ <div class="d-flex fill-height align-center justify-center">
180
+ <v-scale-transition>
181
+ <v-icon v-if="isSelected" color="white" icon="mdi-close-circle-outline"
182
+ size="48"></v-icon>
183
+ </v-scale-transition>
184
+ </div>
185
+ </v-slide-group-item>
186
+ </v-slide-group>
187
+ </v-sheet>
188
+
189
+ <!--List of events in this department-->
190
+ <v-sheet class="mx-auto sliderProducts row align-items-stretch items-row justify-content-center"
191
+ v-if="department?.products?.products_id?.type === 'department' && events?.length">
192
+ <h4 style="left: 15px; position: relative;">{{ callouts?.menus?.[3]?.name }}
193
+ {{ department?.name }}</h4>
194
+ <v-slide-group v-model="model" class="pa-4" selected-class="bg-success" show-arrows>
195
+ <v-slide-group-item v-slot="{ isSelected, toggle, selectedClass }"
196
+ v-for="products in events" :key="products">
197
+ <productCard :product="products?.events_id" :class="['ma-4', selectedClass]"
198
+ @click="toggle" />
199
+ <div class="d-flex fill-height align-center justify-center">
200
+ <v-scale-transition>
201
+ <v-icon v-if="isSelected" color="white" icon="mdi-close-circle-outline"
202
+ size="48"></v-icon>
203
+ </v-scale-transition>
204
+ </div>
205
+ </v-slide-group-item>
206
+ </v-slide-group>
207
+ </v-sheet>
208
+ <!---->
209
+
210
+ <!--List of spaces in the department-->
211
+ <v-sheet class="mx-auto sliderProducts row align-items-stretch items-row justify-content-center"
212
+ v-if="department?.spaces?.length">
213
+ <h4 style="left: 15px; position: relative;">{{ callouts?.menus?.[4]?.name }}
214
+ {{ department?.name }}</h4>
215
+ <v-slide-group v-model="model" class="pa-4" selected-class="bg-success" show-arrows>
216
+ <v-slide-group-item v-slot="{ isSelected, toggle, selectedClass }"
217
+ v-for="spaces in department?.spaces" :key="spaces">
218
+ <spaces :space="spaces?.spaces_id" :class="['ma-4', selectedClass]" @click="toggle" />
219
+ <div class="d-flex fill-height align-center justify-center">
220
+ <v-scale-transition>
221
+ <v-icon v-if="isSelected" color="white" icon="mdi-close-circle-outline"
222
+ size="48"></v-icon>
223
+ </v-scale-transition>
224
+ </div>
225
+ </v-slide-group-item>
226
+ </v-slide-group>
227
+ </v-sheet>
228
+ </v-row>
229
+ </v-card>
230
+ </div>
231
+ </div>
232
+ </template>
233
+
234
+ <script setup>
235
+ import productCard from '#commerce/app/components/catalog/product/productCard.vue'
236
+ import travel from '@/components/categories/travel.vue'
237
+ import deals from '@/components/categories/deals.vue'
238
+ import timeComponent from '@/components/categories/time/time.vue'
239
+ import weather from '@/components/categories/weather/weather.vue'
240
+
241
+ const route = useRoute()
242
+ const model = ref(null)
243
+ import useDirectusRequest from '#shared/app/composables/useDirectusRequest'
244
+ const { readItems, readItem, getAssetUrl } = useDirectusRequest()
245
+
246
+ const slug = computed(() => {
247
+ const s = route.params.slug
248
+ return Array.isArray(s) ? s[0] : s
249
+ })
250
+
251
+ const { data: departmentRaw } = await useAsyncData('department', async () => {
252
+ const resp = await readItems('departments', {
253
+ fields: [
254
+ '*',
255
+ 'categories.categories_id.*',
256
+ 'spaces.spaces_id.*',
257
+ 'products.products_id.*',
258
+ 'products.products_id.image.*',
259
+ 'shorts.shorts_id.*',
260
+ 'shops.shops_id.*',
261
+ 'image.*'
262
+ ],
263
+ filter: { slug: { _eq: slug.value } },
264
+ limit: 1
265
+ })
266
+ return resp?.data || resp || []
267
+ })
268
+
269
+ const department = computed(() => departmentRaw.value?.[0] || null)
270
+
271
+ const { data: introProducts } = await useAsyncData('introProducts', async () => {
272
+ const resp = await readItems('departments', { fields: ['*', { '*': ['*'] }], limit: 2 })
273
+ return resp?.data || resp || []
274
+ })
275
+
276
+ const { data: best } = await useAsyncData('best', async () => {
277
+ const resp = await readItems('departments', {
278
+ fields: ['*', 'products.products_id.*', 'images.*'],
279
+ limit: 10,
280
+ filter: { showcases: { showcases_id: { name: { _eq: 'Best Sellers' } } } }
281
+ })
282
+ return resp?.data || resp || []
283
+ })
284
+
285
+ const {
286
+ data: latestProducts
287
+ } = await useAsyncData('latestProducts', () => {
288
+ return $directus.request($readItems('departments', {
289
+ fields: ['*',
290
+ 'products.products_id.*',
291
+ 'images.*'
292
+ ],
293
+ limit: 10,
294
+ filter: {
295
+ products: {
296
+ products_id: {
297
+ const { data: latestProducts } = await useAsyncData('latestProducts', async () => {
298
+ const resp = await readItems('departments', {
299
+ fields: ['*', 'products.products_id.*', 'images.*'],
300
+ limit: 10,
301
+ filter: {
302
+ data: limitProducts
303
+ } = await useAsyncData('limitProducts', () => {
304
+ return $directus.request($readItems('departments', {
305
+ fields: ['*',
306
+ 'products.products_id.*',
307
+ 'images.*'
308
+ ],
309
+ }
310
+ })
311
+ return resp?.data || resp || []
312
+ })
313
+ products_id: {
314
+ status: {
315
+ _eq: "published"
316
+ }
317
+ }
318
+ },
319
+ }
320
+ }))
321
+ })
322
+
323
+ const {
324
+ data: events
325
+ } = await useAsyncData('events', () => {
326
+ return $directus.request($readItems('departments', {
327
+ fields: ['*',
328
+ 'products.products_id.*',
329
+ 'images.*'
330
+ ],
331
+ limit: 10,
332
+ filter: {
333
+ products: {
334
+ products_id: {
335
+ type: {
336
+ _eq: "event"
337
+ }
338
+ }
339
+ },
340
+ }
341
+ }))
342
+ })
343
+
344
+ const {
345
+ data: callouts
346
+ } = await useAsyncData('callouts', () => {
347
+ return $directus.request($readItem('callouts', '2'))
348
+ })
349
+
350
+ useHead({
351
+ title: computed(() => department?.value?.name || 'Department Page')
352
+ });
353
+ </script>
@@ -0,0 +1,114 @@
1
+ <template>
2
+ <div v-if="category">
3
+
4
+ <!-- Special Categories -->
5
+ <div v-if="category.slug === 'charts'">
6
+ <charts />
7
+ </div>
8
+
9
+ <div v-else-if="category.slug === 'radio-stations'">
10
+ <stations />
11
+ </div>
12
+
13
+ <div v-else-if="category.slug === 'eats'">
14
+ <eats />
15
+ </div>
16
+
17
+ <div v-else-if="category.slug === 'restaurants'">
18
+ <div v-for="(shop, i) in restaurantsList" :key="i">
19
+ <restaurants :restaurant="shop" />
20
+ </div>
21
+ </div>
22
+
23
+ <!-- Default Category Layout -->
24
+ <v-card variant="text" v-else>
25
+ <v-toolbar :style="`background-color: ${category?.color}; color: ${category?.colortext}`">
26
+ <v-toolbar-title><NuxtLink :to="`/departments/${category?.departments?.[0]?.departments_id?.name}`">Meeovi {{ category?.departments?.[0]?.departments_id?.name }}</NuxtLink> - {{ category?.name }}</v-toolbar-title>
27
+ <v-slide-group show-arrows v-if="category?.categories?.length">
28
+ <v-slide-group-item v-slot="{ isSelected, toggle }">
29
+ <v-menu>
30
+ <template #activator="{ props }">
31
+ <v-btn :color="isSelected ? 'primary' : undefined" class="ma-2" v-bind="props"
32
+ variant="text">
33
+ Categories
34
+ </v-btn>
35
+ </template>
36
+
37
+ <v-list class="departmentMenu">
38
+ <v-row>
39
+ <v-col cols="3" v-for="sub in category.categories" :key="sub?.categories_id?.id">
40
+ <v-list-item>
41
+ <NuxtLink :to="`/departments/categories/${sub.categories_id.id}`">
42
+ {{ sub.categories_id.name }}
43
+ </NuxtLink>
44
+ </v-list-item>
45
+ </v-col>
46
+ </v-row>
47
+ </v-list>
48
+ </v-menu>
49
+ </v-slide-group-item>
50
+
51
+ <v-slide-group-item v-for="menu in category.menus" :key="menu.id" v-slot="{ isSelected, toggle }">
52
+ <v-btn :color="isSelected ? 'primary' : undefined" class="ma-2" :href="menu.url">
53
+ {{ menu.name }}
54
+ </v-btn>
55
+ </v-slide-group-item>
56
+ </v-slide-group>
57
+ </v-toolbar>
58
+ </v-card>
59
+
60
+ <!-- Product List -->
61
+ <v-row>
62
+ <v-col cols="3" v-for="productRel in category.products" :key="productRel.products_id.id">
63
+ <productCard :product="productRel.products_id" />
64
+ </v-col>
65
+ </v-row>
66
+
67
+ </div>
68
+
69
+ <!-- Loading / Not Found -->
70
+ <div v-else class="p-10 text-center text-xl text-neutral-700">
71
+ Loading category...
72
+ </div>
73
+ </template>
74
+
75
+ <script setup>
76
+ import charts from '~/components/categories/charts.vue'
77
+ import stations from '~/components/categories/stations.vue'
78
+ import eats from '~/components/categories/eats.vue'
79
+ import restaurants from '~/components/categories/restaurants.vue'
80
+ import productCard from '~/components/catalog/product/productCard.vue'
81
+
82
+ const route = useRoute()
83
+ import useDirectusRequest from '#shared/app/composables/useDirectusRequest'
84
+ const { readItems, readItem } = useDirectusRequest()
85
+
86
+ const slug = computed(() => {
87
+ const s = route.params.slug
88
+ return Array.isArray(s) ? s[0] : s
89
+ })
90
+
91
+ const { data: categoryRaw } = await useAsyncData('categoryRaw', async () => {
92
+ const resp = await readItems('categories', {
93
+ fields: ['*', 'tags.tags_id.*', 'departments.departments_id.*', 'products.products_id.*', 'products.products_id.image.*', 'menus.*', 'image.*'],
94
+ filter: { slug: { _eq: slug.value } },
95
+ limit: 1
96
+ })
97
+ return resp?.data || resp || []
98
+ })
99
+
100
+ // Unwrap array cleanly
101
+ const category = computed(() => categoryRaw.value?.[0] || null)
102
+
103
+
104
+ // FETCH SHOPS FOR RESTAURANTS CATEGORY
105
+ const { data: restaurantsList } = await useAsyncData('restaurantsList', async () => {
106
+ const resp = await readItems('shops', { fields: ['*'] })
107
+ return resp?.data || resp || []
108
+ })
109
+
110
+ // SEO
111
+ useHead({
112
+ title: computed(() => category.value?.name || 'Category Page')
113
+ })
114
+ </script>
@@ -0,0 +1,66 @@
1
+ <template>
2
+ <div>
3
+ <section data-bs-version="5.1" class="firmm4_features1 features1 cid-uhBuptnWmV" id="features1-9v"
4
+ data-sortbtn="btn-primary">
5
+ <div class="container-fluid">
6
+ <div class="row justify-content-center">
7
+ <div class="card">
8
+ <div class="card_wrapper">
9
+ <div class="card-box">
10
+ <div class="icon_block">
11
+ <div class="iconfont-wrapper">
12
+ <span class="mbr-iconfont mobi-mbri-cart-full mobi-mbri"></span>
13
+ </div>
14
+ </div>
15
+ <p class="card-text mbr-fonts-style display-4">Invoice: {{ invoice?.id }}</p>
16
+ <p class="card-text mbr-fonts-style display-4">Invoice Date: {{ new Date(invoice?.created_at).toLocaleDateString() }}</p>
17
+ <p class="card-text mbr-fonts-style display-4">Order #: {{ invoice?.order_id?.orders_id?.id }}</p>
18
+ <p class="card-text mbr-fonts-style display-4">Order Date: {{ new Date(invoice?.updated_at).toLocaleDateString() }}
19
+ </p>
20
+ <p class="card-text mbr-fonts-style display-4">Bill to Name: {{ invoice?.user?.first_name }} {{ invoice?.user?.last_name }}</p>
21
+ <p class="card-text mbr-fonts-style display-4">Status: {{ invoice?.state }}</p>
22
+ <p class="card-text mbr-fonts-style display-4">Grand Total (Base): {{ invoice?.base_grand_total }}</p>
23
+ <p class="card-text mbr-fonts-style display-4">Grand Total (Purchased): {{ invoice?.grand_total }}</p>
24
+ <p class="btn_link mbr-fonts-style display-4"><NuxtLink :to="`/commerce/invoice/${invoice?.id}`" class="text-secondary">View<span class="mobi-mbri mobi-mbri-right mbr-iconfont"></span></NuxtLink></p>
25
+ </div>
26
+ </div>
27
+ </div>
28
+ </div>
29
+ </div>
30
+ </section>
31
+ </div>
32
+ </template>
33
+
34
+ <script setup>
35
+ import {
36
+ ref,
37
+ onMounted
38
+ } from 'vue';
39
+ const route = useRoute();
40
+ const {
41
+ $directus,
42
+ $readItem
43
+ } = useNuxtApp()
44
+ const user = useSupabaseUser()
45
+
46
+ const {
47
+ data: invoice
48
+ } = await useAsyncData('invoice', () => {
49
+ return $directus.request($readItem('invoices', route.params.id, {
50
+ filter: {
51
+ user: {
52
+ _eq: `${user?.id}`
53
+ }
54
+ },
55
+ limit: 1
56
+ })).then(response => response?.[0])
57
+ })
58
+
59
+ useHead({
60
+ title: 'Invoice' + invoice?.value?.id || 'Invoice Page',
61
+ })
62
+
63
+ definePageMeta({
64
+ //middleware: ['auth-logged-in'],
65
+ })
66
+ </script>