HistoryItem.vue 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. <template>
  2. <article class="result item">
  3. <h1>
  4. <a
  5. :href="'/texts/'+item.id+'/'+item.textid"
  6. @click.prevent="onclick"
  7. @keyup.enter="onclick"
  8. v-html="item.title"
  9. />
  10. </h1>
  11. <h2>
  12. <a
  13. :href="'/texts/'+item.id+'/'+item.textid"
  14. @click.prevent="onclick"
  15. @keyup.enter="onclick"
  16. v-html="item.editionTitle"
  17. />
  18. </h2>
  19. <!-- <p v-if="preview" class="preview" v-html="preview" /> -->
  20. <aside
  21. v-if="item.pages || item.size"
  22. >
  23. <span v-if="item.pages && item.pages.range">{{ item.pages.prefix }} {{ item.pages.range }}</span>
  24. <span v-if="item.pages && item.size && item.pages.range && item.size.quantity"> | </span>
  25. <span v-if="item.size && item.size.quantity">{{ item.size.quantity }} {{ item.size.unit }}</span>
  26. </aside>
  27. </article>
  28. </template>
  29. <script>
  30. import { mapActions } from 'vuex'
  31. export default {
  32. name: 'HistoryItem',
  33. props: {
  34. item: {
  35. type: Object,
  36. required: true
  37. }
  38. },
  39. methods: {
  40. ...mapActions({
  41. navigateToHistoryItem: 'History/navigateToItem'
  42. }),
  43. onclick () {
  44. console.log('clicked on history item', this.item)
  45. this.navigateToHistoryItem(this.item)
  46. }
  47. }
  48. }
  49. </script>
  50. <style lang="scss" scoped>
  51. </style>