Skip to content
Snippets Groups Projects
Timeline.vue 2.54 KiB
Newer Older
  • Learn to ignore specific revisions
  • Eliot Berriot's avatar
    Eliot Berriot committed
    <template>
    
    Bat's avatar
    Bat committed
      <div class="main pusher" v-title="'Instance Timeline'">
    
    Eliot Berriot's avatar
    Eliot Berriot committed
        <div class="ui vertical center aligned stripe segment">
    
          <div v-if="isLoading" :class="['ui', {'active': isLoading}, 'inverted', 'dimmer']">
    
    Bat's avatar
    Bat committed
            <div class="ui text loader">{{ $t('Loading timeline...') }}</div>
    
          </div>
          <div v-else class="ui text container">
    
    Bat's avatar
    Bat committed
            <h1 class="ui header">{{ $t('Recent activity on this instance') }}</h1>
    
    Eliot Berriot's avatar
    Eliot Berriot committed
            <div class="ui feed">
              <component
                class="event"
                v-for="(event, index) in events"
                :key="event.id + index"
                v-if="components[event.type]"
                :is="components[event.type]"
                :event="event">
              </component>
            </div>
          </div>
        </div>
      </div>
    </template>
    
    <script>
    import {mapState} from 'vuex'
    
    import { WebSocketBridge } from 'django-channels'
    import axios from 'axios'
    import logger from '@/logging'
    
    Eliot Berriot's avatar
    Eliot Berriot committed
    
    import Like from '@/components/activity/Like'
    import Listen from '@/components/activity/Listen'
    
    export default {
      data () {
        return {
    
    Eliot Berriot's avatar
    Eliot Berriot committed
          components: {
            'Like': Like,
            'Listen': Listen
          }
        }
      },
    
      created () {
        this.openWebsocket()
        this.fetchEvents()
      },
    
      destroyed () {
        this.disconnect()
      },
    
    Eliot Berriot's avatar
    Eliot Berriot committed
      computed: {
        ...mapState({
          events: state => state.instance.events
        })
    
      },
      methods: {
        fetchEvents () {
          this.isLoading = true
          let self = this
          axios.get('/activity/').then((response) => {
            self.isLoading = false
            self.$store.commit('instance/events', response.data.results)
          })
        },
    
        disconnect () {
          if (!this.bridge) {
            return
          }
          this.bridge.socket.close(1000, 'goodbye', {keepClosed: true})
        },
    
        openWebsocket () {
          if (!this.$store.state.auth.authenticated) {
            return
          }
    
          let self = this
          let token = this.$store.state.auth.token
          // let token = 'test'
          const bridge = new WebSocketBridge()
    
          bridge.connect(
            `/api/v1/instance/activity?token=${token}`,
            null,
            {reconnectInterval: 5000})
          bridge.listen(function (event) {
            logger.default.info('Received timeline update', event)
            self.$store.commit('instance/event', event)
          })
          bridge.socket.addEventListener('open', function () {
            console.log('Connected to WebSocket')
          })
        }
    
    Eliot Berriot's avatar
    Eliot Berriot committed
      }
    }
    </script>
    
    <!-- Add "scoped" attribute to limit CSS to this component only -->
    <style scoped>
    </style>