Update app download page to use flathub (#5188)

This commit is contained in:
Prospector
2026-01-22 11:36:56 -08:00
committed by GitHub
parent 86b0de3cee
commit 772e0ee220
5 changed files with 73 additions and 25 deletions

View File

@@ -23,6 +23,9 @@
"app-marketing.download.download-rpm": {
"message": "Download the RPM"
},
"app-marketing.download.flathub": {
"message": "Get it on Flathub"
},
"app-marketing.download.linux": {
"message": "Linux"
},
@@ -38,9 +41,6 @@
"app-marketing.download.terms": {
"message": "By downloading Modrinth App you agree to our <terms-link>Terms</terms-link> and <privacy-link>Privacy Policy</privacy-link>."
},
"app-marketing.download.third-party-packages": {
"message": "Third-party packages"
},
"app-marketing.download.title": {
"message": "Download Modrinth App (Beta)"
},
@@ -197,6 +197,15 @@
"app-marketing.hero.more-download-options": {
"message": "More Download Options"
},
"app-marketing.hide-other-packages": {
"message": "Hide other packages"
},
"app-marketing.not-recommended": {
"message": "We don't recommend you use these unless you know what you're doing."
},
"app-marketing.show-other-packages": {
"message": "Show other packages"
},
"auth.authorize.action.authorize": {
"message": "Authorize"
},

View File

@@ -3,12 +3,14 @@ import {
BoxIcon,
DownloadIcon,
EditIcon,
LinkIcon,
FlathubIcon,
IssuesIcon,
SearchIcon,
SendIcon,
TrashIcon,
} from '@modrinth/assets'
import {
Accordion,
Avatar,
Badge,
Checkbox,
@@ -452,6 +454,22 @@ const messages = defineMessages({
id: 'app-marketing.download.download-beta',
defaultMessage: 'Download the beta',
},
getItOnFlathub: {
id: 'app-marketing.download.flathub',
defaultMessage: 'Get it on Flathub',
},
showOtherPackages: {
id: 'app-marketing.show-other-packages',
defaultMessage: 'Show other packages',
},
hideOtherPackages: {
id: 'app-marketing.hide-other-packages',
defaultMessage: 'Hide other packages',
},
notRecommended: {
id: 'app-marketing.not-recommended',
defaultMessage: `We don't recommend you use these unless you know what you're doing.`,
},
downloadTheAppImage: {
id: 'app-marketing.download.download-appimage',
defaultMessage: 'Download the AppImage',
@@ -464,10 +482,6 @@ const messages = defineMessages({
id: 'app-marketing.download.download-rpm',
defaultMessage: 'Download the RPM',
},
thirdPartyPackages: {
id: 'app-marketing.download.third-party-packages',
defaultMessage: 'Third-party packages',
},
downloadTerms: {
id: 'app-marketing.download.terms',
defaultMessage:
@@ -1156,22 +1170,34 @@ useSeoMeta({
</div>
</div>
<div class="description apple">
<a :href="linuxLinks.appImage || undefined" download="">
<DownloadIcon />
<span>{{ formatMessage(messages.downloadTheAppImage) }}</span>
</a>
<a :href="linuxLinks.deb || undefined" download="">
<DownloadIcon />
<span>{{ formatMessage(messages.downloadTheDEB) }}</span>
</a>
<a :href="linuxLinks.rpm || undefined" download="">
<DownloadIcon />
<span>{{ formatMessage(messages.downloadTheRPM) }}</span>
</a>
<a :href="linuxLinks.thirdParty || undefined" download="">
<LinkIcon />
<span>{{ formatMessage(messages.thirdPartyPackages) }}</span>
<a href="https://flathub.org/en/apps/com.modrinth.ModrinthApp" target="_blank">
<FlathubIcon />
<span>{{ formatMessage(messages.getItOnFlathub) }}</span>
</a>
<Accordion
class="mt-2 flex flex-col"
content-class="flex flex-col items-start gap-2 mt-2 text-sm"
button-class="text-sm text-secondary bg-transparent p-0 w-fit text-left m-0 active:scale-[0.98] transition-transform"
>
<template #title="{ open }">
{{ formatMessage(open ? messages.hideOtherPackages : messages.showOtherPackages) }}
</template>
<span class="grid grid-cols-[auto_1fr] gap-2 text-left text-orange"
><IssuesIcon class="mt-1" /> {{ formatMessage(messages.notRecommended) }}</span
>
<a :href="linuxLinks.appImage || undefined" download="" class="text-primary">
<DownloadIcon />
<span>{{ formatMessage(messages.downloadTheAppImage) }}</span>
</a>
<a :href="linuxLinks.deb || undefined" download="" class="text-primary">
<DownloadIcon />
<span>{{ formatMessage(messages.downloadTheDEB) }}</span>
</a>
<a :href="linuxLinks.rpm || undefined" download="" class="text-primary">
<DownloadIcon />
<span>{{ formatMessage(messages.downloadTheRPM) }}</span>
</a>
</Accordion>
</div>
</div>
</div>
@@ -2148,13 +2174,17 @@ useSeoMeta({
a {
display: flex;
align-items: flex-start;
align-items: center;
gap: var(--gap-sm);
justify-content: center;
&:hover {
cursor: pointer;
}
span {
text-align: left;
}
}
&.apple {