mirror of
https://github.com/tachiyomiorg/website.git
synced 2024-12-20 23:22:00 +01:00
Add Repo button and rewrite Getting started (#1114)
* Add repo button to Extensions * Remove replace prefix * Some more extension changes * Changes to Getting started guide * Encode url * Update website/src/docs/guides/getting-started.md Co-authored-by: arkon <4098258+arkon@users.noreply.github.com> * Update website/src/docs/guides/getting-started.md Co-authored-by: arkon <4098258+arkon@users.noreply.github.com> * Update website/src/docs/guides/getting-started.md Co-authored-by: arkon <4098258+arkon@users.noreply.github.com> * Update website/src/docs/guides/getting-started.md Co-authored-by: arkon <4098258+arkon@users.noreply.github.com> * Update website/src/docs/guides/getting-started.md Co-authored-by: arkon <4098258+arkon@users.noreply.github.com> * Address PR comments * Tweak Google Analytics tag --------- Co-authored-by: arkon <4098258+arkon@users.noreply.github.com>
This commit is contained in:
parent
927a95cdf5
commit
8714179973
149
website/src/.vitepress/theme/components/AddRepoButton.vue
Normal file
149
website/src/.vitepress/theme/components/AddRepoButton.vue
Normal file
@ -0,0 +1,149 @@
|
|||||||
|
<script setup lang="ts">
|
||||||
|
/// <reference types="@types/gtag.js" />
|
||||||
|
|
||||||
|
function handleAnalytics() {
|
||||||
|
window.gtag?.('event', 'Add', {
|
||||||
|
event_category: 'Extension',
|
||||||
|
event_label: 'Repository',
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
const url = new URL('tachiyomi://add-repo')
|
||||||
|
url.searchParams.append('url', 'https://raw.githubusercontent.com/tachiyomiorg/extensions/repo/index.min.json')
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<template>
|
||||||
|
<div v-if="!isAndroid">
|
||||||
|
<div class="action-buttons">
|
||||||
|
<a
|
||||||
|
class="action-button primary"
|
||||||
|
href="/docs/guides/getting-started"
|
||||||
|
>
|
||||||
|
Get started
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
<span class="version-disclaimer">
|
||||||
|
Requires <strong>Android 6.0</strong> or higher.
|
||||||
|
</span>
|
||||||
|
<div class="custom-block warning">
|
||||||
|
<p class="custom-block-title">
|
||||||
|
Unsupported operating system
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
<strong>Tachiyomi</strong> is an <strong>Android app</strong> only.
|
||||||
|
Use an <strong>Android device</strong> to download and install the app.
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div v-if="isAndroid">
|
||||||
|
<div class="action-buttons">
|
||||||
|
<a
|
||||||
|
class="action-button primary"
|
||||||
|
:href="url"
|
||||||
|
@click="handleAnalytics()"
|
||||||
|
>
|
||||||
|
<IconDownload />
|
||||||
|
<span class="text">Add repository</span>
|
||||||
|
<span class="version">Official</span>
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
<span class="version-disclaimer">
|
||||||
|
Requires <strong>Tachiyomi 0.15.2</strong> or higher.
|
||||||
|
</span>
|
||||||
|
<div class="custom-block danger">
|
||||||
|
<p class="custom-block-title">
|
||||||
|
Caution
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
Beware that any third-party repository or extension can contain malware.
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<style lang="stylus">
|
||||||
|
.action-buttons {
|
||||||
|
display: flex
|
||||||
|
gap: 0.75em
|
||||||
|
justify-content: center
|
||||||
|
align-items: center
|
||||||
|
margin: 0.75em auto
|
||||||
|
}
|
||||||
|
|
||||||
|
.action-button {
|
||||||
|
display: inline-block
|
||||||
|
border: 1px solid transparent
|
||||||
|
text-align: center
|
||||||
|
font-weight: 600
|
||||||
|
white-space: nowrap
|
||||||
|
transition: color 0.25s, border-color 0.25s, background-color 0.25s
|
||||||
|
cursor: pointer
|
||||||
|
transition: all 0.3s ease
|
||||||
|
border-radius: 20px
|
||||||
|
padding: 0 20px
|
||||||
|
line-height: 38px
|
||||||
|
font-size: 14px
|
||||||
|
|
||||||
|
&:hover {
|
||||||
|
text-decoration: none !important
|
||||||
|
}
|
||||||
|
|
||||||
|
&.primary {
|
||||||
|
border-color: var(--vp-button-brand-border)
|
||||||
|
color: var(--vp-button-brand-text)
|
||||||
|
background-color: var(--vp-button-brand-bg)
|
||||||
|
|
||||||
|
&:hover {
|
||||||
|
border-color: var(--vp-button-brand-hover-border)
|
||||||
|
color: var(--vp-button-brand-hover-text)
|
||||||
|
background-color: var(--vp-button-brand-hover-bg)
|
||||||
|
}
|
||||||
|
|
||||||
|
&:active {
|
||||||
|
border-color: var(--vp-button-brand-active-border)
|
||||||
|
color: var(--vp-button-brand-active-text)
|
||||||
|
background-color: var(--vp-button-brand-active-bg)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
&.secondary {
|
||||||
|
border-color: var(--vp-button-alt-border)
|
||||||
|
color: var(--vp-button-alt-text)
|
||||||
|
background-color: var(--vp-button-alt-bg)
|
||||||
|
|
||||||
|
&:hover {
|
||||||
|
border-color: var(--vp-button-alt-hover-border)
|
||||||
|
color: var(--vp-button-alt-hover-text)
|
||||||
|
background-color: var(--vp-button-alt-hover-bg)
|
||||||
|
}
|
||||||
|
|
||||||
|
&:active {
|
||||||
|
border-color: var(--vp-button-alt-active-border)
|
||||||
|
color: var(--vp-button-alt-active-text)
|
||||||
|
background-color: var(--vp-button-alt-active-bg)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
svg {
|
||||||
|
display: inline-block
|
||||||
|
vertical-align: middle
|
||||||
|
margin-right: 0.5em
|
||||||
|
font-size: 1.25em
|
||||||
|
}
|
||||||
|
|
||||||
|
.text {
|
||||||
|
margin-right: 10px
|
||||||
|
}
|
||||||
|
|
||||||
|
.version {
|
||||||
|
font-size: 0.8em
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
.version-disclaimer {
|
||||||
|
display: block
|
||||||
|
text-align: center
|
||||||
|
margin: 0.75em auto
|
||||||
|
font-size: 0.75rem
|
||||||
|
}
|
||||||
|
</style>
|
@ -1,25 +1,24 @@
|
|||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { computed, toRefs } from 'vue'
|
import { toRefs } from 'vue'
|
||||||
import { langName, simpleLangName } from '../../../config/scripts/languages'
|
|
||||||
import type { Extension } from '../../queries/useExtensionsRepositoryQuery'
|
import type { Extension } from '../../queries/useExtensionsRepositoryQuery'
|
||||||
import ExtensionItem from './ExtensionItem.vue'
|
import ExtensionItem from './ExtensionItem.vue'
|
||||||
|
|
||||||
const props = defineProps<{ list: Extension[], totalCount: number }>()
|
const props = defineProps<{ list: Extension[], totalCount: number }>()
|
||||||
const { list } = toRefs(props)
|
const { list } = toRefs(props)
|
||||||
|
|
||||||
const groupName = computed(() => {
|
/* const groupName = computed(() => {
|
||||||
const firstItem = list.value[0]
|
const firstItem = list.value[0]
|
||||||
|
|
||||||
return firstItem.lang === 'en'
|
return firstItem.lang === 'en'
|
||||||
? simpleLangName(firstItem.lang)
|
? simpleLangName(firstItem.lang)
|
||||||
: langName(firstItem.lang)
|
: langName(firstItem.lang)
|
||||||
})
|
}) */
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<div class="extension-group">
|
<div class="extension-group">
|
||||||
<h2>
|
<h2>
|
||||||
<span>{{ groupName }}</span>
|
<span>Official extensions</span>
|
||||||
|
|
||||||
<span class="extensions-total">
|
<span class="extensions-total">
|
||||||
Total:
|
Total:
|
||||||
@ -31,7 +30,7 @@ const groupName = computed(() => {
|
|||||||
|
|
||||||
<ExtensionItem
|
<ExtensionItem
|
||||||
v-for="extension in list"
|
v-for="extension in list"
|
||||||
:id="extension.pkg.replace('eu.kanade.tachiyomi.extension.', '')"
|
:id="extension.pkg"
|
||||||
:key="extension.apk"
|
:key="extension.apk"
|
||||||
:item="extension"
|
:item="extension"
|
||||||
/>
|
/>
|
||||||
|
@ -6,7 +6,6 @@ import { computed, nextTick, onMounted, reactive, ref, watch } from 'vue'
|
|||||||
import { simpleLangName } from '../../../config/scripts/languages'
|
import { simpleLangName } from '../../../config/scripts/languages'
|
||||||
import useExtensionsRepositoryQuery from '../../queries/useExtensionsRepositoryQuery'
|
import useExtensionsRepositoryQuery from '../../queries/useExtensionsRepositoryQuery'
|
||||||
import type { Extension } from '../../queries/useExtensionsRepositoryQuery'
|
import type { Extension } from '../../queries/useExtensionsRepositoryQuery'
|
||||||
import ExtensionFilters from './ExtensionFilters.vue'
|
|
||||||
import ExtensionList from './ExtensionList.vue'
|
import ExtensionList from './ExtensionList.vue'
|
||||||
import type { Sort } from './ExtensionFilters.vue'
|
import type { Sort } from './ExtensionFilters.vue'
|
||||||
|
|
||||||
@ -102,12 +101,12 @@ watch([isLoading, loadingInstance], async ([newIsLoading]) => {
|
|||||||
</script>
|
</script>
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<ExtensionFilters
|
<!-- <ExtensionFilters
|
||||||
v-model:search="filters.search"
|
v-model:search="filters.search"
|
||||||
v-model:lang="filters.lang"
|
v-model:lang="filters.lang"
|
||||||
v-model:sort="filters.sort"
|
v-model:sort="filters.sort"
|
||||||
:extensions="extensions ?? []"
|
:extensions="extensions ?? []"
|
||||||
/>
|
/> -->
|
||||||
<div class="extensions">
|
<div class="extensions">
|
||||||
<ExtensionList v-if="!isLoading" :extensions="filteredExtensions" />
|
<ExtensionList v-if="!isLoading" :extensions="filteredExtensions" />
|
||||||
</div>
|
</div>
|
||||||
|
@ -14,35 +14,53 @@ Essential information to help you get set up with Tachiyomi.
|
|||||||
|
|
||||||
## Installation guide
|
## Installation guide
|
||||||
|
|
||||||
### 1. Downloading Tachiyomi
|
### Downloading Tachiyomi
|
||||||
|
|
||||||
1. Visit our [download](/download/) page to get the latest version of **Tachiyomi**.
|
1. Visit our [download](/download/) page to get the latest version of **Tachiyomi**.
|
||||||
1. After the download is complete, open the `tachiyomi-{{ release.stable.tag_name }}.apk` file.
|
2. After the download is complete, open the `.apk` file.
|
||||||
1. Proceed with the installation process.
|
3. Proceed with the installation process.
|
||||||
|
|
||||||
### 2. Adding sources
|
### Adding sources
|
||||||
|
|
||||||
Once **Tachiyomi** is installed on your device, you can install extensions to access a wide range of sources.
|
Once **Tachiyomi** is installed on your device, you can bring your own content to read from various sources:
|
||||||
|
|
||||||
1. Open the **Tachiyomi** app.
|
:::: tabs
|
||||||
1. Navigate to the "**Browse**" section.
|
== Local source
|
||||||
1. Tap on the "**Extensions**" tab.
|
Read content stored locally on your device.
|
||||||
1. Look for the extension you want to use and press the "**INSTALL**" button next to it.
|
|
||||||
1. Proceed with the installation process.
|
|
||||||
|
|
||||||
![Installing extensions](/docs/guides/getting-started/installing-extensions.light.webp#light =414x245)
|
See the [Local source guide](/docs/guides/local-source/) for instructions.
|
||||||
|
== External repositories
|
||||||
|
External repositories add additional sources to **Tachiyomi**. You can add external repositories by going to <nav to="browse"> and tapping **Extension repos**.
|
||||||
|
|
||||||
![Installing extensions](/docs/guides/getting-started/installing-extensions.dark.webp#dark =414x245)
|
Once there, you can add repositories by inputing URLs ending with `index.min.json`. A small set of extensions are available [here](/extensions/).
|
||||||
|
|
||||||
::: tip INSTALL PERMISSION
|
::: danger Caution
|
||||||
Depending on your device settings, you might need to grant **Tachiyomi** permission to install unknown apps.
|
Tachiyomi will not provide resources for any unofficial repositories. Beware that any third-party repositories or extensions will have full access to the app and may contain malware.
|
||||||
|
|
||||||
![Security warning](/docs/guides/getting-started/security-warning.webp =546x165)
|
|
||||||
|
|
||||||
> Relevant guide: [Enabling Third-Party Installations](/docs/faq/browse/extensions#enabling-third-party-installations)
|
|
||||||
:::
|
:::
|
||||||
|
|
||||||
### 3. Adding series to your library
|
Once you've added a repository, go to <nav to="extensions"> and refresh the extensions list.
|
||||||
|
|
||||||
|
You can now tap the download button next to extensions to install them.
|
||||||
|
|
||||||
|
> You may need to [enable third-party installations](/docs/faq/browse/extensions#enabling-third-party-installations).
|
||||||
|
|
||||||
|
::: tip Official repository
|
||||||
|
Tachiyomi has an official extension repository, you can use the **Add repository** button on the [Extensions](/extensions/) page, or copy the url manually below.
|
||||||
|
> `https://raw.githubusercontent.com/tachiyomiorg/extensions/repo/index.min.json`
|
||||||
|
:::
|
||||||
|
|
||||||
|
::: danger Caution
|
||||||
|
Beware that any third-party repository or extension can contain malware.
|
||||||
|
:::
|
||||||
|
== Manual extensions
|
||||||
|
Extensions can be manually installed through `.apk` files.
|
||||||
|
|
||||||
|
::: danger Caution
|
||||||
|
Tachiyomi will not provide resources for any unofficial extensions. Beware that any third-party repositories or extensions will have full access to the app and may contain malware.
|
||||||
|
:::
|
||||||
|
::::
|
||||||
|
|
||||||
|
### Adding series to your library
|
||||||
|
|
||||||
After installing the desired extension, you'll find it in the **Sources** tab.
|
After installing the desired extension, you'll find it in the **Sources** tab.
|
||||||
|
|
||||||
|
@ -9,10 +9,16 @@ next: false
|
|||||||
|
|
||||||
# Extensions
|
# Extensions
|
||||||
|
|
||||||
Extensions can also be installed directly from the app.
|
By default, **Tachiyomi** comes without any extensions.
|
||||||
|
You can choose to read local content, manually add extensions, or include an external repository.
|
||||||
|
|
||||||
|
**Tachiyomi** maintains only one official repository; any other repositories are unofficial and have no affiliation with us.
|
||||||
|
|
||||||
|
<AddRepoButton/>
|
||||||
|
|
||||||
<ExtensionsWrapper/>
|
<ExtensionsWrapper/>
|
||||||
|
|
||||||
<script setup>
|
<script setup>
|
||||||
|
import AddRepoButton from '@theme/components/AddRepoButton.vue'
|
||||||
import ExtensionsWrapper from '@theme/components/Extensions/ExtensionsWrapper.vue'
|
import ExtensionsWrapper from '@theme/components/Extensions/ExtensionsWrapper.vue'
|
||||||
</script>
|
</script>
|
||||||
|
Loading…
Reference in New Issue
Block a user