mirror of
				https://github.com/KevinMidboe/planetposen.git
				synced 2025-10-29 17:50:32 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			86 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			86 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | |
|   <main id="content">
 | |
|     <div class="top-show-sm col-wrap max-width">
 | |
|       <div class="page-header">
 | |
|         <h1>Webshop</h1>
 | |
|         <p>New bags are on sale every monday. Grab one now while they're in stock!</p>
 | |
|       </div>
 | |
|       <div v-if="products && products.length" class="products">
 | |
|           <product-card v-for="product in products" :product="product" />
 | |
|       </div>
 | |
| 
 | |
|       <span v-else>
 | |
|         No products found
 | |
|       </span>
 | |
|     </div>
 | |
|   </main>
 | |
| </template>
 | |
| 
 | |
| <script>
 | |
| import ProductCard from '@/components/ui/ProductCard';
 | |
| 
 | |
| export default {
 | |
|   components: { ProductCard },
 | |
|   data() {
 | |
|     return {
 | |
|       products: []
 | |
|     }
 | |
|   },
 | |
|   created() {
 | |
|     fetch('http://localhost:30010/api/products')
 | |
|       .then(resp => resp.json())
 | |
|       .then(products => this.products = products)
 | |
|       .then(_ => this.products = this.products.concat(this.products))
 | |
|   }
 | |
| }
 | |
| </script>
 | |
| 
 | |
| <style lang="scss" scoped>
 | |
| @import '../styles/variables';
 | |
| 
 | |
| .page-header {
 | |
|   max-width: 840px;
 | |
|   margin: auto;
 | |
|   text-align: center;
 | |
| 
 | |
|   padding: 1.5rem 0 3rem 0;
 | |
|   > h1 {
 | |
|     margin-bottom: 2.5rem;
 | |
|   }
 | |
| 
 | |
|   @include mobile {
 | |
|     padding: 1rem 0;
 | |
| 
 | |
|     > h1 {
 | |
|       margin-bottom: 0.5rem;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .products {
 | |
|   display: grid;
 | |
|   grid-template-columns: 1fr 1fr 1fr;
 | |
|   grid-gap: 48px 0;
 | |
| 
 | |
|   @include tablet {
 | |
|     grid-template-columns: 1fr 1fr;
 | |
|   }
 | |
|   @include mobile {
 | |
|     grid-template-columns: 1fr;
 | |
|   }
 | |
| 
 | |
|   > div {
 | |
|     padding: 0 32px;
 | |
| 
 | |
|     @include tablet {
 | |
|       padding: 0 16px;
 | |
|     }
 | |
| 
 | |
|     @include mobile {
 | |
|       padding: 0 8px;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| </style>
 |