lbry.tech/.vuepress/components/GithubFeed.vue

165 lines
5.1 KiB
Vue
Raw Normal View History

2018-05-12 12:03:21 +02:00
<template>
<div id="github-feed">
<div class="last-updated" v-on:click="updateFeed">Last updated: {{ formatDate(lastUpdated) }}</div>
<div v-for="event in events" class="event">
2018-05-12 20:13:12 +02:00
<a v-bind:href="generateGithubUrl('actor',event)" target="_blank">
2018-05-12 12:03:21 +02:00
<img v-bind:src="event.actor.avatar_url" class="avatar"> {{ event.actor.display_login }}
</a>
<template v-if="event.type == 'CommitCommentEvent'">
2018-05-12 20:13:12 +02:00
commented on <a v-bind:href="generateGithubUrl('comment', event)">commit</a>
2018-05-12 12:03:21 +02:00
</template>
<template v-else-if="event.type == 'CreateEvent'">
created {{ event.payload.ref_type }} '{{ event.payload.ref }}'
</template>
<template v-else-if="event.type == 'DeleteEvent'">
deleted {{ event.payload.ref_type }} '{{ event.payload.ref }}'
</template>
<template v-else-if="event.type == 'ForkEvent'">
2018-05-12 20:13:12 +02:00
forked <a v-bind:href="generateGithubUrl('repo', event)" target="_blank">{{ event.repo.name }}</a> to <a v-bind:href="generateGithubUrl('forkee', event)" target="_blank">{{ event.payload.forkee.name }}</a>
2018-05-12 12:03:21 +02:00
</template>
<template v-else-if="event.type == 'IssueCommentEvent'">
2018-05-12 20:13:12 +02:00
commented on <template v-if="event.payload.issue.pull_request">pull request</template><template v-else>issue</template>&nbsp;<a v-bind:href="generateGithubUrl('issue', event)" target="_blank">{{ event.payload.issue.title }}</a>
2018-05-12 12:03:21 +02:00
</template>
<template v-else-if="event.type == 'IssuesEvent'">
2018-05-12 20:13:12 +02:00
{{ event.payload.action }} issue <a v-bind:href="generateGithubUrl('issue', event)" target="_blank">{{ event.payload.issue.title }}</a>
2018-05-12 12:03:21 +02:00
</template>
<template v-else-if="event.type == 'PullRequestEvent'">
2018-05-12 20:13:12 +02:00
{{ event.payload.action }} pull request <a v-bind:href="generateGithubUrl('pull_request', event)" target="_blank">{{ event.payload.pull_request.title }}</a>
</template>
<template v-else-if="event.type == 'PullRequestReviewCommentEvent'">
2018-05-12 20:13:12 +02:00
commented on pull request <a v-bind:href="generateGithubUrl('pull_request', event)" target="_blank">{{ event.payload.pull_request.title }}</a>
2018-05-12 12:03:21 +02:00
</template>
<template v-else-if="event.type == 'PushEvent'">
2018-05-12 20:13:12 +02:00
pushed to <a v-bind:href="generateGithubUrl('push', event)" target="_blank">{{ refToBranch(event.payload.ref) }}</a>
2018-05-12 12:03:21 +02:00
</template>
<template v-else-if="event.type == 'ReleaseEvent'">
2018-05-12 20:13:12 +02:00
released <a v-bind:href="generateGithubUrl('release', event)" target="_blank">{{ event.payload.release.tag_name }}</a>
2018-05-12 12:03:21 +02:00
</template>
<template v-else-if="event.type == 'WatchEvent'">
starred the repo
</template>
2018-05-12 20:13:12 +02:00
in <a v-bind:href="generateGithubUrl('repo', event)" target="_blank">{{ event.repo.name }}</a>
2018-05-12 12:18:55 +02:00
<div class="time-ago">{{ event.created_at | moment('from') }}</div>
2018-05-12 12:03:21 +02:00
</div>
</div>
</template>
<script>
export default {
data () {
return {
events: [],
updateInterval: {},
lastUpdated: new Date()
}
},
name: 'GithubFeed',
mounted () {
this.updateFeed();
this.updateInterval = setInterval(this.updateFeed, 60*1000);
},
methods: {
updateFeed () {
var component = this;
component.$http.get('//beta.lbry.tech/github-feed').then(function(response) {
component.events = response.body;
});
component.lastUpdated = new Date();
},
2018-05-12 20:13:12 +02:00
refToBranch (ref) {
2018-05-12 12:03:21 +02:00
2018-05-12 20:13:12 +02:00
return ref.replace('refs/heads/','');
2018-05-12 12:03:21 +02:00
},
formatDate (date) {
return date.toLocaleString('en-US');
2018-05-12 20:13:12 +02:00
},
generateGithubUrl (type, event) {
switch(type) {
case 'actor':
return 'https://github.com/' + event.actor.display_login;
break;
case 'comment':
return event.payload.comment.html_url;
break;
case 'repo':
return 'https://github.com' + event.repo.name;
break;
case 'forkee':
return 'https://github.com' + event.payload.forkee.full_name;
break;
case 'issue':
return event.payload.issue.html_url;
break;
case 'pull_request':
return event.payload.pull_request.html_url;
break;
case 'release':
return event.payload.release.html_url;
break;
case 'push':
return 'https://github.com/' + event.repo.name + '/tree/' + event.payload.ref.replace('refs/heads/','');
break;
}
},
rewriteGithubApiUrl (url) {
url = url.replace('api.github.com', 'github.com');
var urlParts = url.split('/');
urlParts.push(urlParts.splice(4).join('/'));
return urlParts[0] + '/' + urlParts[1] + '/' + urlParts[2] + '/' + urlParts[4];
2018-05-12 12:03:21 +02:00
}
}
};
</script>
<style lang="scss">
#github-feed {
.last-updated {
text-align: right;
color: #777;
font-style: italic;
}
.event {
padding: 0.5rem 0;
border-bottom: 1px solid #ccc;
}
.avatar {
width: 2rem;
height: 2rem;
border-radius: 1rem;
vertical-align: middle;
margin-right: 0.5rem;
}
2018-05-12 12:18:55 +02:00
.time-ago {
color: #777;
font-style: italic;
font-size: 0.7rem;
float: right;
padding: 0.7rem 0 0 0;
}
2018-05-12 12:03:21 +02:00
}
</style>