Updated docs with QR Codes
All checks were successful
Ascently - Docs Deploy / build-and-push (push) Successful in 4m26s
All checks were successful
Ascently - Docs Deploy / build-and-push (push) Successful in 4m26s
This commit is contained in:
159
docs/src/components/DownloadButtons.astro
Normal file
159
docs/src/components/DownloadButtons.astro
Normal file
@@ -0,0 +1,159 @@
|
||||
---
|
||||
import { Tabs, TabItem } from "@astrojs/starlight/components";
|
||||
import { Card, CardGrid } from "@astrojs/starlight/components";
|
||||
import { LinkButton } from "@astrojs/starlight/components";
|
||||
import QRCode from "./QRCode.astro";
|
||||
import { downloadLinks, requirements } from "../config";
|
||||
|
||||
interface Props {
|
||||
showQR?: boolean;
|
||||
}
|
||||
|
||||
const { showQR = false } = Astro.props;
|
||||
|
||||
const hasLink = (link: string | undefined) => link && link.trim() !== "";
|
||||
---
|
||||
|
||||
<Tabs syncKey="platform">
|
||||
<TabItem label="Android" icon="laptop">
|
||||
<CardGrid>
|
||||
{
|
||||
hasLink(downloadLinks.android.releases) && (
|
||||
<Card title="Direct APK Download" icon="download">
|
||||
<p>Download the latest APK from the Releases page.</p>
|
||||
<p style="text-align: center;">
|
||||
<LinkButton
|
||||
href={downloadLinks.android.releases}
|
||||
variant="primary"
|
||||
icon="external"
|
||||
>
|
||||
Download APK
|
||||
</LinkButton>
|
||||
</p>
|
||||
{showQR && (
|
||||
<p style="text-align: center;">
|
||||
<QRCode
|
||||
data={downloadLinks.android.releases}
|
||||
size={200}
|
||||
alt="QR code for APK download"
|
||||
/>
|
||||
</p>
|
||||
)}
|
||||
</Card>
|
||||
)
|
||||
}
|
||||
|
||||
{
|
||||
hasLink(downloadLinks.android.obtainium) && (
|
||||
<Card title="Obtainium" icon="setting">
|
||||
<p>Use Obtainium for automatic updates.</p>
|
||||
<p style="text-align: center;">
|
||||
<LinkButton
|
||||
href={downloadLinks.android.obtainium}
|
||||
variant="primary"
|
||||
icon="external"
|
||||
>
|
||||
Get on Obtainium
|
||||
</LinkButton>
|
||||
</p>
|
||||
{showQR && (
|
||||
<p style="text-align: center;">
|
||||
<QRCode
|
||||
data={downloadLinks.android.obtainium}
|
||||
size={200}
|
||||
alt="QR code for Obtainium"
|
||||
/>
|
||||
</p>
|
||||
)}
|
||||
</Card>
|
||||
)
|
||||
}
|
||||
|
||||
{
|
||||
hasLink(downloadLinks.android.playStore) && (
|
||||
<Card title="Google Play Store" icon="rocket">
|
||||
<p>Download from the official Google Play Store.</p>
|
||||
<p style="text-align: center;">
|
||||
<LinkButton
|
||||
href={downloadLinks.android.playStore}
|
||||
variant="primary"
|
||||
icon="external"
|
||||
>
|
||||
Get on Play Store
|
||||
</LinkButton>
|
||||
</p>
|
||||
{showQR && (
|
||||
<p style="text-align: center;">
|
||||
<QRCode
|
||||
data={downloadLinks.android.playStore}
|
||||
size={200}
|
||||
alt="QR code for Play Store"
|
||||
/>
|
||||
</p>
|
||||
)}
|
||||
</Card>
|
||||
)
|
||||
}
|
||||
</CardGrid>
|
||||
|
||||
<p><strong>Requirements:</strong> {requirements.android}</p>
|
||||
</TabItem>
|
||||
|
||||
<TabItem label="iOS" icon="apple">
|
||||
<CardGrid>
|
||||
{
|
||||
hasLink(downloadLinks.ios.appStore) && (
|
||||
<Card title="App Store" icon="apple">
|
||||
<p>Download from the official App Store.</p>
|
||||
<p style="text-align: center;">
|
||||
<LinkButton
|
||||
href={downloadLinks.ios.appStore}
|
||||
variant="primary"
|
||||
icon="external"
|
||||
>
|
||||
Download on App Store
|
||||
</LinkButton>
|
||||
</p>
|
||||
{showQR && (
|
||||
<p style="text-align: center;">
|
||||
<QRCode
|
||||
data={downloadLinks.ios.appStore}
|
||||
size={200}
|
||||
alt="QR code for App Store"
|
||||
/>
|
||||
</p>
|
||||
)}
|
||||
</Card>
|
||||
)
|
||||
}
|
||||
|
||||
{
|
||||
hasLink(downloadLinks.ios.testFlight) && (
|
||||
<Card title="TestFlight Beta" icon="rocket">
|
||||
<p>Join the TestFlight beta program.</p>
|
||||
<p style="text-align: center;">
|
||||
<LinkButton
|
||||
href={downloadLinks.ios.testFlight}
|
||||
variant="secondary"
|
||||
icon="external"
|
||||
>
|
||||
Join TestFlight
|
||||
</LinkButton>
|
||||
</p>
|
||||
{showQR && (
|
||||
<p style="text-align: center;">
|
||||
<QRCode
|
||||
data={downloadLinks.ios.testFlight}
|
||||
size={200}
|
||||
alt="QR code for TestFlight"
|
||||
/>
|
||||
</p>
|
||||
)}
|
||||
</Card>
|
||||
)
|
||||
}
|
||||
</CardGrid>
|
||||
|
||||
<p><strong>Requirements:</strong> {requirements.ios}</p>
|
||||
</TabItem>
|
||||
</Tabs>
|
||||
Reference in New Issue
Block a user