2020-03-05 06:11:00 +01:00
|
|
|
<template>
|
|
|
|
<div class="downloadContainer">
|
|
|
|
<button class="downloadForkButton" @click="downloadFork">
|
|
|
|
{{ downloadLabel }}
|
|
|
|
</button>
|
|
|
|
<button class="githubForkButton" :onclick="githubLink">
|
|
|
|
{{ githubLabel }}
|
|
|
|
</button>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
|
|
|
import axios from "axios";
|
|
|
|
|
|
|
|
export default {
|
|
|
|
props: {
|
|
|
|
forkName: {
|
|
|
|
type: String,
|
|
|
|
required: true
|
|
|
|
},
|
|
|
|
downloadLabel: {
|
|
|
|
type: String,
|
|
|
|
default: "Download"
|
|
|
|
},
|
|
|
|
downloadLink: {
|
|
|
|
type: String,
|
|
|
|
required: true
|
|
|
|
},
|
|
|
|
githubLabel: {
|
|
|
|
type: String,
|
|
|
|
default: "GitHub"
|
|
|
|
},
|
|
|
|
githubLink: {
|
|
|
|
type: String,
|
|
|
|
required: true
|
|
|
|
}
|
|
|
|
},
|
2020-03-15 15:24:22 -04:00
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
tagName: "",
|
|
|
|
browserDownloadUrl: ""
|
|
|
|
};
|
|
|
|
},
|
2020-03-05 06:11:00 +01:00
|
|
|
|
|
|
|
async mounted() {
|
|
|
|
const { data } = await axios.get(this.$props.downloadLink);
|
|
|
|
// Maybe eventually some release has more than the apk in assets.
|
|
|
|
const apkAsset = data.assets.find(a => a.name.includes(".apk"));
|
|
|
|
// Set the values.
|
|
|
|
this.$data.tagName = data.tag_name;
|
|
|
|
this.$data.browserDownloadUrl = apkAsset.browser_download_url;
|
|
|
|
},
|
|
|
|
|
|
|
|
methods: {
|
|
|
|
downloadFork() {
|
|
|
|
this.$swal({
|
|
|
|
title: "Downloading",
|
|
|
|
text: this.$props.forkName + " is being downloaded.",
|
|
|
|
icon: "success",
|
|
|
|
focusConfirm: false,
|
|
|
|
focusCancel: false,
|
|
|
|
timer: 5000,
|
|
|
|
timerProgressBar: true,
|
|
|
|
customClass: {
|
|
|
|
confirmButton: "download-confirm-button",
|
|
|
|
container: "download-container"
|
|
|
|
},
|
|
|
|
showClass: {
|
|
|
|
popup: "animated pulse faster"
|
|
|
|
},
|
|
|
|
hideClass: {
|
|
|
|
popup: "animated zoomOut faster"
|
|
|
|
}
|
|
|
|
});
|
2020-03-15 15:24:22 -04:00
|
|
|
window.location.assign(
|
|
|
|
this.$data.browserDownloadUrl || this.$props.downloadLink
|
|
|
|
);
|
2020-04-28 05:00:49 +02:00
|
|
|
window.ga("send", "event", "Action", "Download", this.$props.forkName);
|
2020-03-05 06:11:00 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
};
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<style lang="stylus">
|
|
|
|
.downloadContainer
|
|
|
|
user-select none
|
|
|
|
text-align center
|
|
|
|
margin 0.3125rem
|
|
|
|
.downloadForkButton
|
|
|
|
.githubForkButton
|
|
|
|
border-radius $buttonBorderRadius
|
|
|
|
border-style none
|
|
|
|
color white
|
|
|
|
font-family $buttonFontFamily
|
|
|
|
font-size 1.125em
|
|
|
|
height 3rem
|
|
|
|
margin 0.3125rem
|
|
|
|
padding 0.625 2em
|
|
|
|
width 8.5rem
|
|
|
|
&:focus
|
|
|
|
outline none
|
|
|
|
outline-style solid
|
|
|
|
&:hover
|
|
|
|
cursor pointer
|
|
|
|
text-decoration none !important
|
|
|
|
background-image linear-gradient(rgba(0, 0, 0, 0.1), rgba(0, 0, 0, 0.1))
|
|
|
|
.downloadForkButton
|
|
|
|
background-color $accentColor
|
|
|
|
.githubForkButton
|
|
|
|
background-color #181818
|
|
|
|
&:hover
|
|
|
|
background-color lighten(#181818, 15)
|
|
|
|
</style>
|