2
0

admin-contribute.vue 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. <template lang='pug'>
  2. v-card(flat)
  3. v-card(flat, tile, :color='$vuetify.dark ? "grey darken-4" : "grey lighten-5"').pa-3.pt-4
  4. .admin-header-icon: v-icon(size='80', color='grey lighten-2') favorite
  5. .headline.primary--text {{ $t('admin:contribute.title') }}
  6. .subheading.grey--text {{ $t('admin:contribute.subtitle') }}
  7. v-card.pa-3
  8. i18next.body-1.pl-3(path='admin:contribute.openSource', tag='div')
  9. v-icon(color='red') favorite
  10. a(href='https://requarks.io', target='_blank') requarks.io
  11. a(href='https://github.com/Requarks/wiki/graphs/contributors', target='_blank') {{ $t('admin:contribute.openSourceContributors') }}
  12. .body-1.pt-3.pl-3 {{ $t('admin:contribute.needYourHelp') }}
  13. v-divider.mt-3
  14. v-subheader {{ $t('admin:contribute.fundOurWork') }}
  15. .body-1.pl-3 {{ $t('admin:contribute.openCollective') }}
  16. v-card-actions.ml-2
  17. v-btn(depressed, color='primary', href='https://opencollective.com/wikijs')
  18. v-icon(left) local_atm
  19. span {{ $t('admin:contribute.makeADonation') }}
  20. .body-1.mt-3.pl-3 {{ $t('admin:contribute.tshirts') }}
  21. v-card-actions.ml-2
  22. v-btn(outline, color='primary', href='https://wikijs.threadless.com')
  23. v-icon(left) shopping_cart
  24. span {{ $t('admin:contribute.shop') }}
  25. v-divider.mt-3
  26. v-subheader {{ $t('admin:contribute.contribute') }}
  27. .body-1.pl-3
  28. ul
  29. i18next(path='admin:contribute.submitAnIdea', tag='li')
  30. a(href='https://requests.requarks.io/wiki', target='_blank') {{ $t('admin:contribute.submitAnIdeaLink') }}
  31. i18next(path='admin:contribute.foundABug', tag='li')
  32. a(href='https://github.com/Requarks/wiki/issues', target='_blank') Github
  33. i18next(path='admin:contribute.helpTranslate', tag='li')
  34. a(href='https://gitter.im/Requarks/wiki', target='_blank') Gitter
  35. v-divider.mt-3
  36. v-subheader {{ $t('admin:contribute.spreadTheWord') }}
  37. .body-1.pl-3
  38. ul
  39. li {{ $t('admin:contribute.talkToFriends') }}
  40. i18next(path='admin:contribute.followUsOnTwitter', tag='li')
  41. a(href='https://twitter.com/requarks', target='_blank') Twitter
  42. v-card
  43. v-toolbar(color='teal', dense, dark)
  44. .subheading Sponsors
  45. v-list(two-line, dense)
  46. template(v-for='(sponsor, idx) in sponsors')
  47. v-list-tile(:key='sponsor.id')
  48. v-list-tile-avatar
  49. img(v-if='sponsor.image', :src='sponsor.image')
  50. v-avatar(v-else, color='teal', size='40')
  51. span.white--text.subheading {{sponsor.name[0].toUpperCase()}}
  52. v-list-tile-content
  53. v-list-tile-title {{sponsor.name}}
  54. v-list-tile-sub-title {{sponsor.description}}
  55. v-list-tile-action(v-if='sponsor.twitter')
  56. v-btn(icon, :href='sponsor.twitter', target='_blank')
  57. icon-twitter(fillColor='#9e9e9e')
  58. v-list-tile-action(v-if='sponsor.website')
  59. v-btn(icon, :href='sponsor.website', target='_blank')
  60. v-icon(color='grey') public
  61. v-divider(v-if='idx < sponsors.length - 1')
  62. v-card
  63. v-toolbar(color='blue-grey', dense, dark)
  64. .subheading Backers
  65. v-list(two-line, dense)
  66. template(v-for='(backer, idx) in backers')
  67. v-list-tile(:key='backer.id')
  68. v-list-tile-avatar
  69. img(v-if='backer.image', :src='backer.image')
  70. v-avatar(v-else, color='blue-grey', size='40')
  71. span.white--text.subheading {{backer.name[0].toUpperCase()}}
  72. v-list-tile-content
  73. v-list-tile-title {{backer.name}}
  74. v-list-tile-sub-title {{backer.description}}
  75. v-list-tile-action(v-if='backer.twitter')
  76. v-btn(icon, :href='backer.twitter', target='_blank')
  77. icon-twitter(fillColor='#9e9e9e')
  78. v-list-tile-action(v-if='backer.website')
  79. v-btn(icon, :href='backer.website', target='_blank')
  80. v-icon(color='grey') public
  81. v-divider(v-if='idx < backers.length - 1')
  82. </template>
  83. <script>
  84. import _ from 'lodash'
  85. import groupsQuery from 'gql/admin/contribute/contribute-query-contributors.gql'
  86. import IconTwitter from 'mdi/Twitter'
  87. export default {
  88. components: {
  89. IconTwitter
  90. },
  91. data() {
  92. return {
  93. contributors: []
  94. }
  95. },
  96. computed: {
  97. sponsors() {
  98. return _.filter(this.contributors, ['tier', 'sponsors'])
  99. },
  100. backers() {
  101. return _.reject(this.contributors, ['tier', 'sponsors'])
  102. }
  103. },
  104. apollo: {
  105. contributors: {
  106. query: groupsQuery,
  107. fetchPolicy: 'network-only',
  108. update: (data) => data.contribute.contributors,
  109. watchLoading (isLoading) {
  110. this.$store.commit(`loading${isLoading ? 'Start' : 'Stop'}`, 'admin-contribute-refresh')
  111. }
  112. }
  113. }
  114. }
  115. </script>
  116. <style lang='scss' scoped>
  117. ul {
  118. margin-left: 1rem;
  119. list-style-type: square;
  120. }
  121. </style>