Card.vue 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. <template>
  2. <article class="card search-card">
  3. <header
  4. @click.prevent="openModalCard"
  5. >
  6. <h1 v-if="isloggedin">{{ item.title }}</h1>
  7. <h4>{{ item.short_description }}</h4>
  8. <span v-if="isloggedin" class="ref">{{ item.reference }}</span>
  9. </header>
  10. <nav class="tools" v-if="isloggedin">
  11. <section class="tool flags">
  12. <span class="btn mdi mdi-folder-outline"/>
  13. <div class="tool-content">
  14. <ul>
  15. <li v-if="flagcolls" v-for="coll in flagcolls" :key="coll.id">
  16. <span
  17. class="flag mdi"
  18. :class="[
  19. flagIsLoading(coll.id) ? 'mdi-loading mdi-spin' : flagIsActive(coll.id) ? 'mdi-close-circle isActive' : 'mdi-plus'
  20. ]"
  21. :collid="coll.id"
  22. @click.prevent="onFlagActionCard"
  23. >
  24. {{ coll.name }}
  25. </span>
  26. </li>
  27. </ul>
  28. </div>
  29. </section>
  30. <section class="tool samples" v-if="item.samples && item.samples.length">
  31. <span class="btn mdi mdi-beaker-outline"/>
  32. <div class="tool-content">
  33. <span class="label">{{ $t("materio.Samples") }}</span>
  34. <ul>
  35. <li
  36. v-for="sample in item.samples"
  37. :key="sample.showroom.id"
  38. >
  39. <span class="showroom">{{ sample.showroom.name }}</span>: {{ sample.location }}
  40. </li>
  41. </ul>
  42. </div>
  43. </section>
  44. </nav>
  45. <section class="images" v-switcher>
  46. <figure
  47. v-for="(img, index) in item.images"
  48. :key="img.url"
  49. >
  50. <img
  51. class="lazy"
  52. v-lazy="index"
  53. :data-src="img.style_cardmedium_url"
  54. :title="img.title"
  55. />
  56. <img
  57. class="blank"
  58. :src="blanksrc"
  59. @click.prevent="openModalCard"
  60. />
  61. </figure>
  62. </section>
  63. <!-- <CoolLightBox
  64. v-if="isloggedin"
  65. :items="item.images"
  66. :index="lightbox_index"
  67. srcName="style_hd_url"
  68. :loop="true"
  69. @close="lightbox_index = null">
  70. </CoolLightBox> -->
  71. </article>
  72. </template>
  73. <script>
  74. import { mapState, mapActions } from 'vuex'
  75. import cardMixins from 'vuejs/components/cardMixins'
  76. import ModalCard from 'vuejs/components/Content/ModalCard'
  77. export default {
  78. name: "Card",
  79. props: ['item'],
  80. mixins: [cardMixins],
  81. components: {
  82. ModalCard
  83. },
  84. data() {
  85. return {
  86. blanksrc:`${drupalSettings.path.themePath}/assets/img/blank.gif`,
  87. loadingFlag: false
  88. // lightbox_index: null
  89. }
  90. },
  91. computed: {
  92. ...mapState({
  93. flagcolls: state => state.User.flagcolls,
  94. isloggedin: state => state.User.isloggedin
  95. })
  96. },
  97. methods: {
  98. ...mapActions({
  99. flagUnflag: 'User/flagUnflag'
  100. }),
  101. flagIsActive(collid) {
  102. // console.log("Card flagIsActive",
  103. // this.item.id,
  104. // this.flagcolls[collid].items,
  105. // this.flagcolls[collid].items.indexOf(this.item.id)
  106. // );
  107. // console.log(this.flagcolls[collid].items_uuids);
  108. // return this.flagcolls[collid].items_uuids.indexOf(this.item.uuid) !== -1;
  109. return this.flagcolls[collid].items.indexOf(this.item.id) !== -1;
  110. },
  111. flagIsLoading(collid) {
  112. // console.log(this.item.uuid);
  113. // console.log(this.flagcolls[collid].items_uuids);
  114. return collid === this.loadingFlag;
  115. },
  116. onFlagActionCard (e) {
  117. console.log("Card onFlagActionCard", e, this.item);
  118. if (!this.loadingFlag) {
  119. let collid = e.target.getAttribute('collid');
  120. let isActive = this.flagIsActive(collid);
  121. let action = isActive ? 'unflag' : 'flag';
  122. // console.log('collid', collid);
  123. // console.log("this.item", this.item);
  124. this.loadingFlag = collid;
  125. this.flagUnflag({ action: action, id: this.item.id, collid: collid})
  126. .then(data => {
  127. console.log("onFlagActionCard then", data);
  128. this.loadingFlag = false;
  129. })
  130. }
  131. },
  132. // onClickImg (e, index) {
  133. // this.lightbox_index = index
  134. // },
  135. openModalCard (e) {
  136. console.log('openModalCard', this.isLoggedin);
  137. if(this.isloggedin){
  138. this.$modal.show(
  139. ModalCard,
  140. { item: this.item },
  141. {
  142. name: `modal-${this.item.id}`,
  143. draggable: true,
  144. width: '850px',
  145. height: '610px'
  146. }
  147. )
  148. }
  149. }
  150. }
  151. }
  152. </script>
  153. <style lang="scss" scoped>
  154. </style>