diff options
Diffstat (limited to 'iridescence')
| -rw-r--r-- | iridescence/src/api/dichroism.js | 58 | ||||
| -rw-r--r-- | iridescence/src/components/InventoryList.vue | 33 | ||||
| -rw-r--r-- | iridescence/src/components/Navbar.vue | 7 | ||||
| -rw-r--r-- | iridescence/src/components/ProductCard.vue (renamed from iridescence/src/components/InventoryCard.vue) | 4 | ||||
| -rw-r--r-- | iridescence/src/components/ProductFilter.vue (renamed from iridescence/src/components/InventoryFilter.vue) | 4 | ||||
| -rw-r--r-- | iridescence/src/components/ProductList.vue | 36 | ||||
| -rw-r--r-- | iridescence/src/components/ProductSearch.vue (renamed from iridescence/src/components/InventorySearch.vue) | 8 | ||||
| -rw-r--r-- | iridescence/src/models/category.js | 14 | ||||
| -rw-r--r-- | iridescence/src/store/index.js | 80 | ||||
| -rw-r--r-- | iridescence/src/views/Home.vue | 18 | 
10 files changed, 131 insertions, 131 deletions
| diff --git a/iridescence/src/api/dichroism.js b/iridescence/src/api/dichroism.js new file mode 100644 index 0000000..2bbad2b --- /dev/null +++ b/iridescence/src/api/dichroism.js @@ -0,0 +1,58 @@ +const _products = [ +  { +    id: 1, +    name: "Beach Box", +    quantity: 0, +    cents: 1100, +    imgPath: "/beach_box.jpg", +    description: "This is a beach box.", +    featured: false, +    categories: ["Fused Glass", ["Beachy"]] +  }, +  { +    id: 2, +    name: "Wind Chime", +    quantity: 0, +    cents: 4500, +    imgPath: "/wind-chime.jpg", +    description: "Makes noise when the wind blows.", +    featured: false, +    categories: ["Fused Glass", ["Beachy"]] +  }, +  { +    id: 3, +    name: "Beach Box", +    quantity: 5, +    cents: 1100, +    imgPath: "/beach_box.jpg", +    description: "This is a beach box.", +    featured: false, +    categories: ["Stained Glass", ["Christmas"]] +  }, +  { +    id: 4, +    name: "Wind Chime", +    quantity: 2, +    cents: 4500, +    imgPath: "/wind-chime.jpg", +    description: "Makes noise when the wind blows.", +    featured: false, +    categories: ["Fused Glass", ["Kiln-y"]] +  }, +  { +    id: 5, +    name: "Beach Box (New!)", +    quantity: 5, +    cents: 1100, +    imgPath: "/beach_box.jpg", +    description: "This is a beach box.", +    featured: true, +    categories: ["Stained Glass", ["Christmas"]] +  } +]; + +export default { +  getProducts() { +    return _products; +  } +}; diff --git a/iridescence/src/components/InventoryList.vue b/iridescence/src/components/InventoryList.vue deleted file mode 100644 index a4962cd..0000000 --- a/iridescence/src/components/InventoryList.vue +++ /dev/null @@ -1,33 +0,0 @@ -<template> -  <div id="inventoryList"> -    <div class="columns is-multiline is-variable is-7-desktop"> -      <div -        class="column is-one-quarter" -        v-for="item in inventory" -        :key="item.id" -      > -        <InventoryCard v-bind="item"></InventoryCard> -      </div> -    </div> -  </div> -</template> - -<script> -import InventoryCard from "@/components/InventoryCard.vue"; - -export default { -  name: "InventoryList", -  components: { -    InventoryCard -  }, -  data() { -    return {}; -  }, -  computed: { -    inventory() { -      return this.$store.getters.inventory; -    } -  }, -  methods: {} -}; -</script> diff --git a/iridescence/src/components/Navbar.vue b/iridescence/src/components/Navbar.vue index 65d5032..551ce5a 100644 --- a/iridescence/src/components/Navbar.vue +++ b/iridescence/src/components/Navbar.vue @@ -77,11 +77,8 @@ export default {        }      },      categories() { -      const inventory = this.$store.getters.inventory; -      console.log(inventory); -      console.log(inventory.map(item => item.categories)); - -      //console.log(cats); +      const products = this.$store.getters.products; +      console.log(products.map(item => item.categories));        return [];      }    }, diff --git a/iridescence/src/components/InventoryCard.vue b/iridescence/src/components/ProductCard.vue index 6bcc548..269e416 100644 --- a/iridescence/src/components/InventoryCard.vue +++ b/iridescence/src/components/ProductCard.vue @@ -1,5 +1,5 @@  <template> -  <div id="inventoryCard"> +  <div id="productCard">      <div class="card">        <div class="card-image">          <figure class="image is-4by3"> @@ -28,7 +28,7 @@  <script>  export default { -  name: "InventoryCard", +  name: "ProductCard",    props: {      id: Number,      name: String, diff --git a/iridescence/src/components/InventoryFilter.vue b/iridescence/src/components/ProductFilter.vue index 349b0f5..6fdd461 100644 --- a/iridescence/src/components/InventoryFilter.vue +++ b/iridescence/src/components/ProductFilter.vue @@ -1,5 +1,5 @@  <template> -  <div id="inventoryFilter"> +  <div id="productFilter">      <aside class="menu">        <p class="menu-label">          Availability @@ -47,6 +47,6 @@  <script>  export default { -  name: "InventoryFilter" +  name: "ProductFilter"  };  </script> diff --git a/iridescence/src/components/ProductList.vue b/iridescence/src/components/ProductList.vue new file mode 100644 index 0000000..537e802 --- /dev/null +++ b/iridescence/src/components/ProductList.vue @@ -0,0 +1,36 @@ +<template> +  <div id="productsList"> +    <div class="columns is-multiline is-variable is-7-desktop"> +      <div +        class="column is-one-quarter" +        v-for="item in products" +        :key="item.id" +      > +        <ProductCard v-bind="item"></ProductCard> +      </div> +    </div> +  </div> +</template> + +<script> +import ProductCard from "@/components/ProductCard.vue"; + +export default { +  name: "ProductsList", +  components: { +    ProductCard +  }, +  data() { +    return {}; +  }, +  computed: { +    products() { +      return this.$store.getters.products; +    } +  }, +  methods: {}, +  created() { +    this.$store.dispatch("refreshProducts"); +  } +}; +</script> diff --git a/iridescence/src/components/InventorySearch.vue b/iridescence/src/components/ProductSearch.vue index 6145246..d452e83 100644 --- a/iridescence/src/components/InventorySearch.vue +++ b/iridescence/src/components/ProductSearch.vue @@ -1,5 +1,5 @@  <template> -  <div id="inventorySearch"> +  <div id="productSearch">      <div class="field is-grouped is-grouped-multiline">        <div class="control is-expanded">          <input @@ -32,7 +32,7 @@  <script>  export default { -  name: "InventorySearch", +  name: "ProductSearch",    data() {      return {        term: "" @@ -40,12 +40,12 @@ export default {    },    computed: {      noResults() { -      return !this.$store.getters.inventory.length; +      return !this.$store.getters.products.length;      }    },    methods: {      updateSearch() { -      this.$store.commit("filterTerm", this.term); +      this.$store.commit("searchTerm", this.term);      }    }  }; diff --git a/iridescence/src/models/category.js b/iridescence/src/models/category.js deleted file mode 100644 index 04966f5..0000000 --- a/iridescence/src/models/category.js +++ /dev/null @@ -1,14 +0,0 @@ - -export class Category { -  name: string; -  subcategory: Category; - -  /** -   * @param {string} name -   * @param {Category=} subcategory -   */ -  constructor(name, subcategory) { -    this.name = name; -    this.subcategory = subcategory; -  } -} diff --git a/iridescence/src/store/index.js b/iridescence/src/store/index.js index b5b0445..e2b40b4 100644 --- a/iridescence/src/store/index.js +++ b/iridescence/src/store/index.js @@ -1,82 +1,38 @@  import Vue from "vue";  import Vuex from "vuex"; +import Dichroism from "@/api/dichroism.js";  Vue.use(Vuex);  export default new Vuex.Store({    state: { -    inventory: [ -      { -        id: 1, -        name: "Beach Box", -        quantity: 0, -        cents: 1100, -        imgPath: "/beach_box.jpg", -        description: "This is a beach box.", -        featured: false, -        category: { name: "Stained Glass", subcategory: { name: "Gardeny" } } -      }, -      { -        id: 2, -        name: "Wind Chime", -        quantity: 0, -        cents: 4500, -        imgPath: "/wind-chime.jpg", -        description: "Makes noise when the wind blows.", -        featured: false, -        categories: ["Fused Glass", ["Beachy"]] -      }, -      { -        id: 3, -        name: "Beach Box", -        quantity: 5, -        cents: 1100, -        imgPath: "/beach_box.jpg", -        description: "This is a beach box.", -        featured: false, -        categories: ["Stained Glass", ["Christmas"]] -      }, -      { -        id: 4, -        name: "Wind Chime", -        quantity: 2, -        cents: 4500, -        imgPath: "/wind-chime.jpg", -        description: "Makes noise when the wind blows.", -        featured: false, -        categories: ["Fused Glass", ["Kiln-y"]] -      }, -      { -        id: 5, -        name: "Beach Box (New!)", -        quantity: 5, -        cents: 1100, -        imgPath: "/beach_box.jpg", -        description: "This is a beach box.", -        featured: true, -        categories: ["Stained Glass", ["Christmas"]] -      } -    ], -    term: "" +    searchTerm: "", +    products: []    },    getters: { -    inventory(state) { -      const term = state.term.toLowerCase(); +    products(state) { +      const searchTerm = state.searchTerm.toLowerCase(); -      return state.inventory.filter(item => { -        // TODO: move into class for items +      return state.products.filter(item => {          return ( -          item.name.toLowerCase().indexOf(term) != -1 || -          item.description.toLowerCase().indexOf(term) != -1 +          item.name.toLowerCase().indexOf(searchTerm) != -1 || +          item.description.toLowerCase().indexOf(searchTerm) != -1          );        });      }    },    mutations: { -    filterTerm(state, term) { -      state.term = term; +    searchTerm(state, term) { +      state.searchTerm = term; +    }, +    setProducts(state, products) { +      state.products = products; +    } +  }, +  actions: { +    refreshProducts({ commit }) { +      commit("setProducts", Dichroism.getProducts());      }    }, -  actions: {},    modules: {}  }); diff --git a/iridescence/src/views/Home.vue b/iridescence/src/views/Home.vue index b01b78d..1212d2c 100644 --- a/iridescence/src/views/Home.vue +++ b/iridescence/src/views/Home.vue @@ -8,7 +8,7 @@        <div class="column is-narrow">          <section class="section">            <div class="box"> -            <InventoryFilter></InventoryFilter> +            <ProductFilter></ProductFilter>            </div>          </section>        </div> @@ -16,10 +16,10 @@        <div class="column">          <div class="container">            <section class="section"> -            <InventorySearch></InventorySearch> +            <ProductSearch></ProductSearch>            </section>            <section class="section"> -            <InventoryList></InventoryList> +            <ProductList></ProductList>            </section>          </div>        </div> @@ -28,16 +28,16 @@  </template>  <script> -import InventoryList from "@/components/InventoryList.vue"; -import InventoryFilter from "@/components/InventoryFilter.vue"; -import InventorySearch from "@/components/InventorySearch.vue"; +import ProductList from "@/components/ProductList.vue"; +import ProductFilter from "@/components/ProductFilter.vue"; +import ProductSearch from "@/components/ProductSearch.vue";  export default {    name: "Home",    components: { -    InventoryList, -    InventorySearch, -    InventoryFilter +    ProductList, +    ProductSearch, +    ProductFilter    }  };  </script> |