mirror of
https://github.com/tachiyomiorg/website.git
synced 2025-01-20 22:11:16 +01:00
Enhance download page (#277)
This commit is contained in:
parent
89e5834ebe
commit
74645d7ca4
19
package-lock.json
generated
19
package-lock.json
generated
@ -9380,6 +9380,11 @@
|
||||
"minimist": "^1.2.5"
|
||||
}
|
||||
},
|
||||
"moment": {
|
||||
"version": "2.27.0",
|
||||
"resolved": "https://registry.npmjs.org/moment/-/moment-2.27.0.tgz",
|
||||
"integrity": "sha512-al0MUK7cpIcglMv3YF13qSgdAIqxHTO7brRtaz3DlSULbqfazqkc5kEjNrLDOM7fsjshoFIihnU8snrP7zUvhQ=="
|
||||
},
|
||||
"move-concurrently": {
|
||||
"version": "1.0.1",
|
||||
"resolved": "https://registry.npmjs.org/move-concurrently/-/move-concurrently-1.0.1.tgz",
|
||||
@ -12823,9 +12828,9 @@
|
||||
}
|
||||
},
|
||||
"sweetalert2": {
|
||||
"version": "9.15.2",
|
||||
"resolved": "https://registry.npmjs.org/sweetalert2/-/sweetalert2-9.15.2.tgz",
|
||||
"integrity": "sha512-evJfoa49s5ZzSmVc62tslNkzlQoCg2GHjB3MQxawfESppvY5AlXKLGQ3nNKxHXKdodKmIHbkl39DgUhcOK7LgQ=="
|
||||
"version": "9.17.1",
|
||||
"resolved": "https://registry.npmjs.org/sweetalert2/-/sweetalert2-9.17.1.tgz",
|
||||
"integrity": "sha512-D/VE2lT/bKd64/RBglLUtQ+3nsftzjzIiP2iqN6zPzPwf+2djIY+4k8Bg430zxRUn4DkZzyIuU58q3n0J43lvw=="
|
||||
},
|
||||
"table": {
|
||||
"version": "5.4.6",
|
||||
@ -13822,6 +13827,14 @@
|
||||
"resolved": "https://registry.npmjs.org/vue-material-design-icons/-/vue-material-design-icons-4.8.0.tgz",
|
||||
"integrity": "sha512-NNbwK/a14mk92ofBvJa6oBdWi+SO2f27pimoCWziirrbN5Nmt9q0pzELOfvqyy0ncoMJ2BLkd8KfQuXIAhL3Fw=="
|
||||
},
|
||||
"vue-moment": {
|
||||
"version": "4.1.0",
|
||||
"resolved": "https://registry.npmjs.org/vue-moment/-/vue-moment-4.1.0.tgz",
|
||||
"integrity": "sha512-Gzisqpg82ItlrUyiD9d0Kfru+JorW2o4mQOH06lEDZNgxci0tv/fua1Hl0bo4DozDV2JK1r52Atn/8QVCu8qQw==",
|
||||
"requires": {
|
||||
"moment": "^2.19.2"
|
||||
}
|
||||
},
|
||||
"vue-router": {
|
||||
"version": "3.3.4",
|
||||
"resolved": "https://registry.npmjs.org/vue-router/-/vue-router-3.3.4.tgz",
|
||||
|
@ -38,8 +38,10 @@
|
||||
"lodash.sortby": "^4.7.0",
|
||||
"marked": "^1.1.1",
|
||||
"material-design-icons": "^3.0.1",
|
||||
"sweetalert2": "^9.17.1",
|
||||
"vue-agile": "^1.1.3",
|
||||
"vue-material-design-icons": "^4.8.0",
|
||||
"vue-moment": "^4.1.0",
|
||||
"vue-sweetalert2": "^3.0.6",
|
||||
"vuepress-plugin-sitemap": "^2.3.1"
|
||||
}
|
||||
|
@ -1,44 +1,27 @@
|
||||
<template>
|
||||
<div class="downloadContainer">
|
||||
<button class="downloadStableButton" @click="downloadStable">
|
||||
{{ downloadStableLabel }}
|
||||
</button>
|
||||
<button class="downloadPreviewButton" @click="downloadPreview">
|
||||
{{ downloadPreviewLabel }}
|
||||
</button>
|
||||
<div id="DownloadButtons">
|
||||
<div class="downloadContainer">
|
||||
<button id="downloadStable" @click="downloadStable" @keyup.enter="downloadStable">
|
||||
<CloudDownloadIcon /> Stable
|
||||
</button>
|
||||
<button id="downloadPreview" @click="downloadPreview" @keyup.enter="downloadPreview">
|
||||
<BugIcon /> Preview
|
||||
</button>
|
||||
</div>
|
||||
<span class="versionNotice">Requires <strong>Android 5.0</strong> or higher.</span>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import axios from "axios";
|
||||
import CloudDownloadIcon from "vue-material-design-icons/CloudDownload.vue";
|
||||
import BugIcon from "vue-material-design-icons/Bug.vue";
|
||||
import { GITHUB_LATEST_API, GITHUB_LATEST_RELEASE, KANADE_LATEST } from "../constants";
|
||||
|
||||
export default {
|
||||
props: {
|
||||
downloadStableTag: {
|
||||
type: String,
|
||||
required: true,
|
||||
},
|
||||
downloadPreviewTag: {
|
||||
type: String,
|
||||
required: true,
|
||||
},
|
||||
downloadStableLabel: {
|
||||
type: String,
|
||||
default: "Stable",
|
||||
},
|
||||
downloadPreviewLabel: {
|
||||
type: String,
|
||||
default: "Preview",
|
||||
},
|
||||
downloadStableUrl: {
|
||||
type: String,
|
||||
default: undefined,
|
||||
},
|
||||
downloadPreviewUrl: {
|
||||
type: String,
|
||||
default: undefined,
|
||||
},
|
||||
components: {
|
||||
CloudDownloadIcon,
|
||||
BugIcon,
|
||||
},
|
||||
|
||||
data() {
|
||||
@ -50,10 +33,8 @@ export default {
|
||||
|
||||
async mounted() {
|
||||
const { data } = await axios.get(GITHUB_LATEST_API);
|
||||
// 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.tagName = data.tag_name.slice(1);
|
||||
this.$data.browserDownloadUrl = apkAsset.browser_download_url;
|
||||
},
|
||||
|
||||
@ -61,96 +42,102 @@ export default {
|
||||
downloadStable() {
|
||||
this.$swal({
|
||||
title: "Downloading",
|
||||
text: `${this.downloadStableLabel} version is being downloaded.`,
|
||||
html: `Started downloading <strong>Tachiyomi Stable</strong>`,
|
||||
icon: "success",
|
||||
focusConfirm: false,
|
||||
focusCancel: false,
|
||||
timer: 5000,
|
||||
timer: 3000,
|
||||
timerProgressBar: true,
|
||||
customClass: {
|
||||
confirmButton: "download-confirm-button",
|
||||
container: "download-container",
|
||||
},
|
||||
showClass: {
|
||||
popup: "animated pulse faster",
|
||||
popup: "animate__animated animate__faster animate__pulse",
|
||||
},
|
||||
hideClass: {
|
||||
popup: "animated zoomOut faster",
|
||||
popup: "animate__animated animate__faster animate__zoomOut",
|
||||
},
|
||||
});
|
||||
window.location.assign(
|
||||
this.$props.downloadStableUrl ||
|
||||
this.$data.browserDownloadUrl ||
|
||||
GITHUB_LATEST_RELEASE
|
||||
);
|
||||
window.ga(
|
||||
"send",
|
||||
"event",
|
||||
"Action",
|
||||
"Download",
|
||||
this.downloadStableTag
|
||||
);
|
||||
window.location.assign(this.$data.browserDownloadUrl || GITHUB_LATEST_RELEASE);
|
||||
window.ga("send", "event", "Action", "Download", "Tachiyomi");
|
||||
},
|
||||
downloadPreview() {
|
||||
this.$swal({
|
||||
title: "Downloading",
|
||||
text: `${this.downloadPreviewLabel} version is being downloaded.`,
|
||||
icon: "success",
|
||||
focusConfirm: false,
|
||||
focusCancel: false,
|
||||
timer: 5000,
|
||||
timerProgressBar: true,
|
||||
customClass: {
|
||||
confirmButton: "download-confirm-button",
|
||||
container: "download-container",
|
||||
},
|
||||
icon: "warning",
|
||||
title: "Are you sure?",
|
||||
html:
|
||||
"<strong>Tachiyomi Preview</strong> is not recommended if you're not willing to test for – and endure – issues.",
|
||||
confirmButtonText: "I am sure.",
|
||||
showCloseButton: true,
|
||||
showCancelButton: false,
|
||||
showClass: {
|
||||
popup: "animated pulse faster",
|
||||
popup: "animate__animated animate__headShake",
|
||||
},
|
||||
hideClass: {
|
||||
popup: "animated zoomOut faster",
|
||||
popup: "animate__animated animate__faster animate__zoomOut",
|
||||
},
|
||||
// eslint-disable-next-line no-shadow
|
||||
}).then((result) => {
|
||||
if (result.value) {
|
||||
this.$swal({
|
||||
icon: "success",
|
||||
title: "Downloading",
|
||||
html: `Started downloading <strong>Tachiyomi Preview</strong>`,
|
||||
confirmButtonText: "Dismiss",
|
||||
showCloseButton: false,
|
||||
showCancelButton: false,
|
||||
timer: 3000,
|
||||
timerProgressBar: true,
|
||||
showClass: {
|
||||
popup: "animate__animated animate__faster animate__pulse",
|
||||
},
|
||||
hideClass: {
|
||||
popup: "animate__animated animate__faster animate__zoomOut",
|
||||
},
|
||||
});
|
||||
window.location.assign(KANADE_LATEST);
|
||||
window.ga("send", "event", "Action", "Download", "Tachiyomi Preview");
|
||||
}
|
||||
});
|
||||
window.location.assign(
|
||||
this.$props.downloadPreviewUrl || KANADE_LATEST
|
||||
);
|
||||
window.ga(
|
||||
"send",
|
||||
"event",
|
||||
"Action",
|
||||
"Download",
|
||||
this.downloadPreviewTag
|
||||
);
|
||||
},
|
||||
},
|
||||
};
|
||||
</script>
|
||||
|
||||
<style lang="stylus">
|
||||
.downloadContainer
|
||||
user-select none
|
||||
#DownloadButtons
|
||||
text-align center
|
||||
margin 0.3125rem
|
||||
.downloadStableButton
|
||||
.downloadPreviewButton
|
||||
border-style none
|
||||
padding 0.625 2em
|
||||
margin 0.3125rem
|
||||
border-radius $buttonBorderRadius
|
||||
font-family $buttonFontFamily
|
||||
font-size 1.125em
|
||||
color white
|
||||
height 3rem
|
||||
width 8.5rem
|
||||
&:focus
|
||||
outline none
|
||||
outline-style solid
|
||||
button
|
||||
display inline-block
|
||||
margin 0.5em 0
|
||||
padding 1em 1em
|
||||
width 9em
|
||||
background $accentColor
|
||||
border none
|
||||
border-radius 4px
|
||||
color #fff
|
||||
font-family inherit
|
||||
font-size 1em
|
||||
font-weight 400
|
||||
letter-spacing 0.02em
|
||||
line-height 1
|
||||
transition background-color .1s ease
|
||||
text-decoration none
|
||||
text-transform uppercase
|
||||
cursor pointer
|
||||
&:hover
|
||||
cursor pointer
|
||||
text-decoration none !important
|
||||
background-image linear-gradient(rgba(0, 0, 0, 0.1), rgba(0, 0, 0, 0.1))
|
||||
.downloadStableButton
|
||||
background-color $accentColor
|
||||
.downloadPreviewButton
|
||||
background-color $accentColorSecondary
|
||||
background darken($accentColor, 10%)
|
||||
&:focus
|
||||
box-shadow 0 0 30px #b1aeae52, 0 0 0 1px #fff, 0 0 0 3px rgba(50, 100, 150, 0.4)
|
||||
outline none
|
||||
.downloadContainer
|
||||
user-select none
|
||||
#download
|
||||
&Stable
|
||||
background-color $accentColor
|
||||
&:hover
|
||||
background-color lighten($accentColor, 10%)
|
||||
&Preview
|
||||
background-color $accentColorSecondary
|
||||
&:hover
|
||||
background-color lighten($accentColorSecondary, 10%)
|
||||
.versionNotice
|
||||
font-size 0.9rem
|
||||
</style>
|
||||
|
31
src/.vuepress/components/ReleaseDate.vue
Normal file
31
src/.vuepress/components/ReleaseDate.vue
Normal file
@ -0,0 +1,31 @@
|
||||
<template>
|
||||
<div class="buildTime">
|
||||
<span :title="releasePublishExact">{{ releasePublishRelative }}</span>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import axios from "axios";
|
||||
import { GITHUB_LATEST_API } from "../constants";
|
||||
|
||||
export default {
|
||||
data() {
|
||||
return {
|
||||
releasePublishRelative: "at an unknown time",
|
||||
releasePublishExact: "Can't connect to GitHub.",
|
||||
};
|
||||
},
|
||||
|
||||
async mounted() {
|
||||
const { data } = await axios.get(GITHUB_LATEST_API);
|
||||
this.$data.releasePublishRelative = this.$moment(data.published_at).fromNow();
|
||||
this.$data.releasePublishExact = this.$moment(data.published_at).toString();
|
||||
},
|
||||
};
|
||||
</script>
|
||||
|
||||
<style lang="stylus" scoped>
|
||||
.buildTime
|
||||
font-weight 500
|
||||
display inline-block
|
||||
</style>
|
@ -1,29 +0,0 @@
|
||||
<template>
|
||||
<div v-html="releaseNotes" class="releaseNotes"></div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import axios from "axios";
|
||||
import marked from "marked";
|
||||
import { GITHUB_LATEST_API } from "../constants";
|
||||
|
||||
export default {
|
||||
data() {
|
||||
return {
|
||||
releaseNotes: "",
|
||||
};
|
||||
},
|
||||
|
||||
async mounted() {
|
||||
const { data } = await axios.get(GITHUB_LATEST_API);
|
||||
this.$data.releaseNotes = marked(data.body);
|
||||
},
|
||||
};
|
||||
</script>
|
||||
|
||||
<style lang="stylus">
|
||||
.releaseNotes
|
||||
white-space
|
||||
h3
|
||||
font-size 1.1rem
|
||||
</style>
|
@ -1,12 +1,10 @@
|
||||
<template>
|
||||
<span v-if="fileName" class="fileNameContainer" title="File name">
|
||||
<MaterialIcon class="fileNameIcon" icon-name="get_app" />
|
||||
<span class="fileName">tachiyomi-{{ this.$data.tagName }}.apk</span>
|
||||
<span class="fileName">tachiyomi-v{{ this.$data.tagName }}.apk</span>
|
||||
<slot />
|
||||
</span>
|
||||
<span v-else class="downloadTag">
|
||||
{{ this.$data.tagName }}
|
||||
</span>
|
||||
<span v-else class="downloadTag">{{ this.$data.tagName }}</span>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
@ -22,14 +20,13 @@ export default {
|
||||
|
||||
data() {
|
||||
return {
|
||||
tagName: "",
|
||||
tagName: "0.0.0",
|
||||
};
|
||||
},
|
||||
|
||||
async mounted() {
|
||||
const { data } = await axios.get(GITHUB_LATEST_API);
|
||||
// Set the values.
|
||||
this.$data.tagName = data.tag_name;
|
||||
this.$data.tagName = data.tag_name.slice(1);
|
||||
},
|
||||
};
|
||||
</script>
|
||||
|
41
src/.vuepress/components/WhatsNew.vue
Normal file
41
src/.vuepress/components/WhatsNew.vue
Normal file
@ -0,0 +1,41 @@
|
||||
<template>
|
||||
<div class="guide whatsNew">
|
||||
<p class="title">What's new</p>
|
||||
<div v-html="whatsNew"></div>
|
||||
<div class="custom-block aside">
|
||||
<p>
|
||||
View the full release
|
||||
<a href="https://github.com/inorichi/tachiyomi/releases/latest" target="_blank" rel="noopener">here</a>
|
||||
</p>
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script>
|
||||
import axios from "axios";
|
||||
import marked from "marked";
|
||||
import { GITHUB_LATEST_API } from "../constants";
|
||||
|
||||
export default {
|
||||
data() {
|
||||
return {
|
||||
whatsNew: "Failed to load data from GitHub.",
|
||||
};
|
||||
},
|
||||
|
||||
async mounted() {
|
||||
const { data } = await axios.get(GITHUB_LATEST_API);
|
||||
this.$data.whatsNew = marked(data.body);
|
||||
},
|
||||
};
|
||||
</script>
|
||||
|
||||
<style lang="stylus">
|
||||
.whatsNew
|
||||
.title
|
||||
text-align center
|
||||
div
|
||||
white-space
|
||||
h3
|
||||
font-size 1.1rem
|
||||
</style>
|
@ -5,6 +5,7 @@ import "vue-material-design-icons/styles.css";
|
||||
|
||||
import { VueAgile } from "vue-agile";
|
||||
import VueSweetalert2 from "vue-sweetalert2";
|
||||
import VueMoment from "vue-moment";
|
||||
|
||||
export default ({
|
||||
Vue, // the version of Vue being used in the VuePress app
|
||||
@ -15,4 +16,5 @@ export default ({
|
||||
// eslint-disable-next-line vue/match-component-file-name
|
||||
Vue.component("Agile", VueAgile);
|
||||
Vue.use(VueSweetalert2);
|
||||
Vue.use(VueMoment);
|
||||
};
|
||||
|
@ -176,4 +176,4 @@ font-feature-settings()
|
||||
|
||||
// Hotfix Mobile Dropdown
|
||||
.sidebar .dropdown-wrapper .dropdown-title
|
||||
pointer-events auto
|
||||
pointer-events auto
|
||||
|
@ -1,21 +1,14 @@
|
||||
<template>
|
||||
<main class="home" aria-labelledby="main-title">
|
||||
<header class="hero">
|
||||
<img
|
||||
v-if="data.heroImage"
|
||||
:src="$withBase(data.heroImage)"
|
||||
:alt="data.heroAlt || 'Logo'"
|
||||
/>
|
||||
<img v-if="data.heroImage" :src="$withBase(data.heroImage)" :alt="data.heroAlt || 'Logo'" />
|
||||
|
||||
<h1 v-if="data.heroText !== null" id="main-title">
|
||||
{{ data.heroText || "Tachiyomi" }}
|
||||
</h1>
|
||||
|
||||
<p v-if="data.tagline !== null" class="description">
|
||||
{{
|
||||
data.tagline ||
|
||||
"Free and open source manga reader for Android"
|
||||
}}
|
||||
{{ data.tagline || "Free and open source manga reader for Android" }}
|
||||
</p>
|
||||
|
||||
<p v-if="data.buttonDownload || data.buttonGuides" class="action">
|
||||
@ -23,8 +16,7 @@
|
||||
v-if="data.buttonDownload"
|
||||
class="action-button action-button__Download"
|
||||
tabindex="0"
|
||||
@click="showDownloads"
|
||||
@keyup.enter="showDownloads"
|
||||
:href="data.buttonDownloadLink"
|
||||
>
|
||||
<CloudDownloadIcon />
|
||||
{{ data.buttonDownload }}
|
||||
@ -42,27 +34,16 @@
|
||||
</header>
|
||||
|
||||
<div v-if="data.features && data.features.length" class="features">
|
||||
<div
|
||||
v-for="(feature, index) in data.features"
|
||||
:key="index"
|
||||
class="feature"
|
||||
>
|
||||
<div v-for="(feature, index) in data.features" :key="index" class="feature">
|
||||
<div class="feature__Details">
|
||||
<h2>{{ feature.title }}</h2>
|
||||
<p>{{ feature.details }}</p>
|
||||
</div>
|
||||
<section class="feature__Animation">
|
||||
<img
|
||||
class="feature__Animation--dark"
|
||||
:src="
|
||||
$withBase('/assets/' + feature.image + '-Dark.png')
|
||||
"
|
||||
/>
|
||||
<img class="feature__Animation--dark" :src="$withBase('/assets/' + feature.image + '-Dark.png')" />
|
||||
<img
|
||||
class="feature__Animation--light"
|
||||
:src="
|
||||
$withBase('/assets/' + feature.image + '-Light.png')
|
||||
"
|
||||
:src="$withBase('/assets/' + feature.image + '-Light.png')"
|
||||
/>
|
||||
</section>
|
||||
</div>
|
||||
@ -82,7 +63,7 @@
|
||||
import axios from "axios";
|
||||
import CloudDownloadIcon from "vue-material-design-icons/CloudDownload.vue";
|
||||
import BookOpenVariantIcon from "vue-material-design-icons/BookOpenVariant.vue";
|
||||
import { GITHUB_LATEST_API, GITHUB_LATEST_RELEASE, KANADE_LATEST } from "../../constants";
|
||||
import { GITHUB_LATEST_API } from "../../constants";
|
||||
|
||||
export default {
|
||||
name: "Home",
|
||||
@ -106,6 +87,7 @@ export default {
|
||||
|
||||
buttonDownload() {
|
||||
return {
|
||||
link: this.data.buttonDownloadLink,
|
||||
text: this.data.buttonDownload,
|
||||
};
|
||||
},
|
||||
@ -121,155 +103,8 @@ export default {
|
||||
async mounted() {
|
||||
const { data } = await axios.get(GITHUB_LATEST_API);
|
||||
const apkAsset = data.assets.find((a) => a.name.includes(".apk"));
|
||||
this.$data.tagName = data.tag_name;
|
||||
this.$data.browserDownloadUrl = apkAsset.browser_download_url;
|
||||
},
|
||||
|
||||
methods: {
|
||||
showDownloads() {
|
||||
this.$swal({
|
||||
title: "Get Tachiyomi for Android",
|
||||
text: "Requires Android 5.0 or newer.",
|
||||
confirmButtonText: "Download",
|
||||
confirmButtonAriaLabel: "Download Tachiyomi",
|
||||
cancelButtonText:
|
||||
"Living on the edge? Get the <strong>Preview</strong>",
|
||||
cancelButtonAriaLabel: "Download Preview",
|
||||
showCloseButton: true,
|
||||
showCancelButton: true,
|
||||
focusConfirm: true,
|
||||
customClass: {
|
||||
container: "showDownloads",
|
||||
popup: "showDownloads__popup",
|
||||
actions: "showDownloads__actions",
|
||||
title: "showDownloads__title",
|
||||
content: "showDownloads__content",
|
||||
confirmButton: "showDownloads__confirmButton",
|
||||
cancelButton: "showDownloads__cancelButton",
|
||||
closeButton: "showDownloads__closeButton",
|
||||
footer: "showDownloads__footer",
|
||||
},
|
||||
showClass: {
|
||||
popup: "animate__animated animate__faster animate__fadeIn",
|
||||
},
|
||||
hideClass: {
|
||||
popup: "animate__animated animate__faster animate__zoomOut",
|
||||
},
|
||||
}).then((result) => {
|
||||
if (result.value) {
|
||||
this.$swal({
|
||||
icon: "success",
|
||||
title: "Downloading",
|
||||
text: "Tachiyomi",
|
||||
confirmButtonText: "Dismiss",
|
||||
showCloseButton: false,
|
||||
showCancelButton: false,
|
||||
timer: 50000,
|
||||
timerProgressBar: true,
|
||||
customClass: {
|
||||
container: "showDownloads",
|
||||
popup: "showDownloads__popup",
|
||||
actions: "showDownloads__actions",
|
||||
title: "showDownloads__title",
|
||||
content: "showDownloads__content",
|
||||
confirmButton: "showDownloads__confirmButton",
|
||||
cancelButton: "showDownloads__cancelButton",
|
||||
closeButton: "showDownloads__closeButton",
|
||||
footer: "showDownloads__footer",
|
||||
},
|
||||
showClass: {
|
||||
popup:
|
||||
"animate__animated animate__faster animate__pulse",
|
||||
},
|
||||
hideClass: {
|
||||
popup:
|
||||
"animate__animated animate__faster animate__zoomOut",
|
||||
},
|
||||
});
|
||||
window.location.assign(
|
||||
this.$data.browserDownloadUrl || GITHUB_LATEST_RELEASE
|
||||
);
|
||||
window.ga(
|
||||
"send",
|
||||
"event",
|
||||
"Action",
|
||||
"Download",
|
||||
"Tachiyomi"
|
||||
);
|
||||
} else if (result.dismiss === "cancel") {
|
||||
this.$swal({
|
||||
icon: "warning",
|
||||
title: "Are you sure?",
|
||||
html:
|
||||
"<strong>Preview</strong> is not recommended if you're not willing to test for – and endure – issues.",
|
||||
confirmButtonText: "I am sure.",
|
||||
showCloseButton: true,
|
||||
showCancelButton: false,
|
||||
customClass: {
|
||||
container: "showDownloads",
|
||||
popup: "showDownloads__popup",
|
||||
actions: "showDownloads__actions",
|
||||
title: "showDownloads__title",
|
||||
content: "showDownloads__content",
|
||||
confirmButton: "showDownloads__confirmButton",
|
||||
cancelButton: "showDownloads__cancelButton",
|
||||
closeButton: "showDownloads__closeButton",
|
||||
footer: "showDownloads__footer",
|
||||
},
|
||||
showClass: {
|
||||
popup: "animate__animated animate__headShake",
|
||||
},
|
||||
hideClass: {
|
||||
popup:
|
||||
"animate__animated animate__faster animate__zoomOut",
|
||||
},
|
||||
// eslint-disable-next-line no-shadow
|
||||
}).then((result) => {
|
||||
if (result.value) {
|
||||
this.$swal({
|
||||
icon: "success",
|
||||
title: "Downloading",
|
||||
text: "Tachiyomi Preview",
|
||||
confirmButtonText: "Dismiss",
|
||||
showCloseButton: false,
|
||||
showCancelButton: false,
|
||||
timer: 5000,
|
||||
timerProgressBar: true,
|
||||
customClass: {
|
||||
container: "showDownloads",
|
||||
popup: "showDownloads__popup",
|
||||
actions: "showDownloads__actions",
|
||||
title: "showDownloads__title",
|
||||
content: "showDownloads__content",
|
||||
confirmButton:
|
||||
"showDownloads__confirmButton",
|
||||
cancelButton: "showDownloads__cancelButton",
|
||||
closeButton: "showDownloads__closeButton",
|
||||
footer: "showDownloads__footer",
|
||||
},
|
||||
showClass: {
|
||||
popup:
|
||||
"animate__animated animate__faster animate__pulse",
|
||||
},
|
||||
hideClass: {
|
||||
popup:
|
||||
"animate__animated animate__faster animate__zoomOut",
|
||||
},
|
||||
});
|
||||
window.location.assign(KANADE_LATEST);
|
||||
window.ga(
|
||||
"send",
|
||||
"event",
|
||||
"Action",
|
||||
"Download",
|
||||
"Tachiyomi Preview"
|
||||
);
|
||||
}
|
||||
});
|
||||
}
|
||||
});
|
||||
},
|
||||
},
|
||||
};
|
||||
</script>
|
||||
|
||||
@ -378,56 +213,6 @@ export default {
|
||||
text-align center
|
||||
color lighten($textColor, 25%)
|
||||
|
||||
.showDownloads
|
||||
button
|
||||
user-select none
|
||||
&__popup
|
||||
width 30em !important
|
||||
&__cancelButton
|
||||
&__confirmButton
|
||||
font-family $buttonFontFamily
|
||||
&__confirmButton
|
||||
width 50% !important
|
||||
margin-left 25% !important
|
||||
margin-right 25% !important
|
||||
margin-bottom 8px !important
|
||||
&__cancelButton
|
||||
background none !important
|
||||
color $textColor !important
|
||||
font-size 0.8rem !important
|
||||
padding 2px !important
|
||||
padding-top 4px !important
|
||||
border-top 1px solid darken($borderColor, 10%) !important
|
||||
border-radius 0px !important
|
||||
strong
|
||||
color $accentColor
|
||||
&:hover
|
||||
cursor pointer
|
||||
opacity 0.8
|
||||
&:focus
|
||||
box-shadow 0 0 30px #b1aeae52, 0 0 0 1px #fff, 0 0 0 3px rgba(50, 100, 150, 0.4)
|
||||
outline none
|
||||
&:hover
|
||||
cursor default
|
||||
&__closeButton
|
||||
border-radius 6px
|
||||
width 1em
|
||||
height 1em
|
||||
margin-top 0.2em
|
||||
margin-right 0.2em
|
||||
&:focus
|
||||
box-shadow 0 0 30px #b1aeae52, 0 0 0 1px #fff, 0 0 0 3px rgba(50, 100, 150, 0.4)
|
||||
outline none
|
||||
&__title
|
||||
border-bottom-width 0 !important
|
||||
font-family $buttonFontFamily !important
|
||||
font-weight 500
|
||||
&__content
|
||||
margin-top -10px
|
||||
font-size 1rem
|
||||
&__footer
|
||||
text-align center
|
||||
|
||||
@keyframes fade
|
||||
0%
|
||||
opacity 1
|
||||
|
@ -6,6 +6,7 @@ meta:
|
||||
lang: en-US
|
||||
heroImage: /icons/logo.svg
|
||||
buttonDownload: Download
|
||||
buttonDownloadLink: /download/
|
||||
buttonGuides: User Guide
|
||||
buttonGuidesLink: /help/guides/getting-started
|
||||
features:
|
||||
|
@ -8,15 +8,8 @@ lang: en-US
|
||||
---
|
||||
|
||||
# Download
|
||||
Download the latest stable version of **Tachiyomi** (**<VersionTag downloadTag/>**) which released <ReleaseDate />.
|
||||
|
||||
Download the latest version of **Tachiyomi** for your Android device.
|
||||
<DownloadButtons />
|
||||
|
||||
::: aside-guide
|
||||
Latest release: **<VersionTag/>**
|
||||
:::
|
||||
|
||||
<DownloadButtons downloadStableTag="Tachiyomi" downloadPreviewTag="Tachiyomi Preview"/>
|
||||
|
||||
::: guide Release notes
|
||||
<ReleaseNotes/>
|
||||
:::
|
||||
<WhatsNew />
|
||||
|
Loading…
x
Reference in New Issue
Block a user