Vue.component('product-display', { props: { premium: { type: Boolean, required: true, }, }, template: `

{{ productName }}

In Stock

Out of Stock

Shipping: {{ shipping }}

  • {{ detail }}
`, data() { return { product: 'Socks', brand: 'Vue Mastery', selectedVariant: 0, details: ['80% cotton', '20% polyester', 'Gender-neutral'], variants: [ { id: 2234, color: 'green', image: './assets/images/socks_green.jpg', quantity: 10, }, { id: 2235, color: 'blue', image: './assets/images/socks_blue.jpg', quantity: 0, }, ], reviews: [], tabs: ['review-form', 'review-list'], activeTab: 'review-form', } }, methods: { addToCart() { this.$emit('add-to-cart', this.variants[this.selectedVariant].id) }, updateProduct(index) { this.selectedVariant = index }, addReview(review) { this.reviews.push(review) }, }, computed: { productName() { return this.brand + ' ' + this.product }, image() { return this.variants[this.selectedVariant].image }, inStock() { return this.variants[this.selectedVariant].quantity }, shipping() { if (this.premium) { return 'Free' } return 2.99 }, }, })