It's just a shopping cart experiment using Vue.js.
This project is built with vue-cli and vuex.
Also, I suggest you to use vue-devtools if you want a see how everything happens.
- Products can be added to the cart if they have an item available on stock.
- Products added to the cart must be removable.
- Checkout must be disabled if cart total is over user limit.
- If a product already exists on the cart, its counter should be updated.
- All products have a shipping price. shipping is defined by the highest shipping price of products added to cart.
- 30% OFF should reduce 30% of the costs on subtotal.
- $100.00 Discount should reduce $100.00 of total.
- Free Shipping should set shipping to zero.
- +$100.00 on limit should increase user limit by $100.00.
{
'firstName': 'Joe',
'lastName': 'Montana',
'limit': 850.00
}
{
'id': 1,
'title': 'iPad 4 Mini',
'price': 500.01,
'inventory': 2,
'shipping': 15.00
},
...
{ 'id': 1, 'title': '30% OFF' },
{ 'id': 2, 'title': '$100.00 Discount' },
{ 'id': 3, 'title': 'Free Shipping' },
{ 'id': 4, 'title': '+ $100.00 on limit' }
yarn install
yarn run serve
yarn run build
yarn run test
yarn run lint
yarn run test:e2e
yarn run test:unit