2020-11-17 10:45:35 +05:30
|
|
|
<template>
|
2022-01-12 16:57:08 +05:30
|
|
|
<div class="flex">
|
|
|
|
<button @click="$router.go(-1) || $router.push('/')">
|
2022-01-31 05:18:27 +05:30
|
|
|
<font-awesome-icon icon="chevron-left" /><span class="ml-1.5" v-t="'actions.back'" />
|
2021-08-22 15:57:09 +05:30
|
|
|
</button>
|
2021-07-20 20:15:17 +05:30
|
|
|
</div>
|
2022-01-12 16:57:08 +05:30
|
|
|
<h1 v-t="'titles.preferences'" class="font-bold text-center" />
|
2020-11-22 10:04:27 +05:30
|
|
|
<hr />
|
2022-08-11 22:42:08 +05:30
|
|
|
<label for="ddlTheme" class="pref">
|
|
|
|
<strong v-t="'actions.theme'" />
|
|
|
|
<select id="ddlTheme" v-model="selectedTheme" class="select w-auto" @change="onChange($event)">
|
|
|
|
<option v-t="'actions.auto'" value="auto" />
|
|
|
|
<option v-t="'actions.dark'" value="dark" />
|
2022-08-11 22:53:18 +05:30
|
|
|
<option v-t="'actions.light'" value="light" />
|
|
|
|
</select>
|
|
|
|
</label>
|
|
|
|
<label class="pref" for="ddlLanguageSelection">
|
|
|
|
<strong v-t="'actions.language_selection'" />
|
|
|
|
<select id="ddlLanguageSelection" v-model="selectedLanguage" class="select w-auto" @change="onChange($event)">
|
|
|
|
<option v-for="language in languages" :key="language.code" :value="language.code" v-text="language.name" />
|
|
|
|
</select>
|
|
|
|
</label>
|
|
|
|
<label class="pref" for="ddlCountrySelection">
|
|
|
|
<strong v-t="'actions.country_selection'" />
|
2022-08-13 14:05:54 +05:30
|
|
|
<select id="ddlCountrySelection" v-model="countrySelected" class="select w-50" @change="onChange($event)">
|
2022-08-11 22:53:18 +05:30
|
|
|
<option v-for="country in countryMap" :key="country.code" :value="country.code" v-text="country.name" />
|
|
|
|
</select>
|
|
|
|
</label>
|
|
|
|
<label class="pref" for="ddlDefaultHomepage">
|
|
|
|
<strong v-t="'actions.default_homepage'" />
|
|
|
|
<select id="ddlDefaultHomepage" v-model="defaultHomepage" class="select w-auto" @change="onChange($event)">
|
|
|
|
<option v-t="'titles.trending'" value="trending" />
|
|
|
|
<option v-t="'titles.feed'" value="feed" />
|
|
|
|
</select>
|
|
|
|
</label>
|
|
|
|
|
2022-08-15 00:01:09 +05:30
|
|
|
<h2 class="text-center" v-t="'titles.player'" />
|
2022-08-11 22:42:08 +05:30
|
|
|
<label class="pref" for="chkAutoPlayVideo">
|
|
|
|
<strong v-t="'actions.autoplay_video'" />
|
|
|
|
<input
|
|
|
|
id="chkAutoPlayVideo"
|
|
|
|
v-model="autoPlayVideo"
|
|
|
|
class="checkbox"
|
|
|
|
type="checkbox"
|
|
|
|
@change="onChange($event)"
|
|
|
|
/>
|
|
|
|
</label>
|
|
|
|
<label class="pref" for="chkAudioOnly">
|
|
|
|
<strong v-t="'actions.audio_only'" />
|
|
|
|
<input id="chkAudioOnly" v-model="listen" class="checkbox" type="checkbox" @change="onChange($event)" />
|
|
|
|
</label>
|
|
|
|
<label class="pref" for="ddlDefaultQuality">
|
|
|
|
<strong v-t="'actions.default_quality'" />
|
|
|
|
<select id="ddlDefaultQuality" v-model="defaultQuality" class="select w-auto" @change="onChange($event)">
|
|
|
|
<option v-t="'actions.auto'" value="0" />
|
|
|
|
<option v-for="resolution in resolutions" :key="resolution" :value="resolution" v-text="`${resolution}p`" />
|
|
|
|
</select>
|
|
|
|
</label>
|
|
|
|
<label class="pref" for="txtBufferingGoal">
|
|
|
|
<strong v-t="'actions.buffering_goal'" />
|
|
|
|
<input
|
|
|
|
id="txtBufferingGoal"
|
|
|
|
v-model="bufferingGoal"
|
2022-08-13 14:05:54 +05:30
|
|
|
class="input w-24"
|
2022-08-11 22:42:08 +05:30
|
|
|
type="text"
|
|
|
|
@change="onChange($event)"
|
|
|
|
/>
|
|
|
|
</label>
|
2022-10-24 04:49:57 +05:30
|
|
|
<label class="pref" for="chkMinimizeComments">
|
|
|
|
<strong v-t="'actions.minimize_comments_default'" />
|
2022-08-11 22:42:08 +05:30
|
|
|
<input
|
2022-10-24 04:49:57 +05:30
|
|
|
id="chkMinimizeComments"
|
|
|
|
v-model="minimizeComments"
|
2022-08-11 22:42:08 +05:30
|
|
|
class="checkbox"
|
|
|
|
type="checkbox"
|
|
|
|
@change="onChange($event)"
|
|
|
|
/>
|
|
|
|
</label>
|
|
|
|
<label class="pref" for="chkMinimizeDescription">
|
|
|
|
<strong v-t="'actions.minimize_description_default'" />
|
|
|
|
<input
|
|
|
|
id="chkMinimizeDescription"
|
|
|
|
v-model="minimizeDescription"
|
|
|
|
class="checkbox"
|
|
|
|
type="checkbox"
|
|
|
|
@change="onChange($event)"
|
|
|
|
/>
|
|
|
|
</label>
|
|
|
|
<label class="pref" for="chkMinimizeRecommendations">
|
|
|
|
<strong v-t="'actions.minimize_recommendations_default'" />
|
|
|
|
<input
|
|
|
|
id="chkMinimizeRecommendations"
|
|
|
|
v-model="minimizeRecommendations"
|
|
|
|
class="checkbox"
|
|
|
|
type="checkbox"
|
|
|
|
@change="onChange($event)"
|
|
|
|
/>
|
|
|
|
</label>
|
2022-11-02 21:40:27 +05:30
|
|
|
<label class="pref" for="chkShowWatchOnYouTube">
|
|
|
|
<strong v-t="'actions.show_watch_on_youtube'" />
|
|
|
|
<input
|
|
|
|
id="chkShowWatchOnYouTube"
|
|
|
|
v-model="showWatchOnYouTube"
|
|
|
|
class="checkbox"
|
|
|
|
type="checkbox"
|
|
|
|
@change="onChange($event)"
|
|
|
|
/>
|
|
|
|
</label>
|
2022-09-11 23:31:58 +05:30
|
|
|
<label class="pref" for="chkStoreSearchHistory">
|
|
|
|
<strong v-t="'actions.store_search_history'" />
|
|
|
|
<input
|
|
|
|
id="chkStoreSearchHistory"
|
|
|
|
v-model="searchHistory"
|
|
|
|
class="checkbox"
|
|
|
|
type="checkbox"
|
|
|
|
@change="onChange($event)"
|
|
|
|
/>
|
|
|
|
</label>
|
2022-08-11 22:42:08 +05:30
|
|
|
<label class="pref" for="chkStoreWatchHistory">
|
|
|
|
<strong v-t="'actions.store_watch_history'" />
|
|
|
|
<input
|
|
|
|
id="chkStoreWatchHistory"
|
|
|
|
v-model="watchHistory"
|
|
|
|
class="checkbox"
|
|
|
|
type="checkbox"
|
|
|
|
@change="onChange($event)"
|
|
|
|
/>
|
|
|
|
</label>
|
2022-09-10 22:38:50 +05:30
|
|
|
<label v-if="watchHistory" class="pref" for="chkHideWatched">
|
|
|
|
<strong v-t="'actions.hide_watched'" />
|
|
|
|
<input id="chkHideWatched" v-model="hideWatched" class="checkbox" type="checkbox" @change="onChange($event)" />
|
|
|
|
</label>
|
2022-08-11 22:42:08 +05:30
|
|
|
<label class="pref" for="ddlEnabledCodecs">
|
|
|
|
<strong v-t="'actions.enabled_codecs'" />
|
|
|
|
<select
|
|
|
|
id="ddlEnabledCodecs"
|
|
|
|
v-model="enabledCodecs"
|
|
|
|
class="select w-auto h-auto"
|
|
|
|
multiple
|
|
|
|
@change="onChange($event)"
|
|
|
|
>
|
|
|
|
<option value="av1">AV1</option>
|
|
|
|
<option value="vp9">VP9</option>
|
|
|
|
<option value="avc">AVC (h.264)</option>
|
|
|
|
</select>
|
|
|
|
</label>
|
|
|
|
<label class="pref" for="chkDisableLBRY">
|
|
|
|
<strong v-t="'actions.disable_lbry'" />
|
|
|
|
<input id="chkDisableLBRY" v-model="disableLBRY" class="checkbox" type="checkbox" @change="onChange($event)" />
|
|
|
|
</label>
|
|
|
|
<label class="pref" for="chkEnableLBRYProxy">
|
|
|
|
<strong v-t="'actions.enable_lbry_proxy'" />
|
|
|
|
<input
|
|
|
|
id="chkEnableLBRYProxy"
|
|
|
|
v-model="proxyLBRY"
|
|
|
|
class="checkbox"
|
|
|
|
type="checkbox"
|
|
|
|
@change="onChange($event)"
|
|
|
|
/>
|
|
|
|
</label>
|
|
|
|
|
|
|
|
<h2 class="text-center">SponsorBlock</h2>
|
|
|
|
<p class="text-center">
|
|
|
|
<span v-t="'actions.uses_api_from'" /><a class="link" href="https://sponsor.ajay.app/">sponsor.ajay.app</a>
|
|
|
|
</p>
|
|
|
|
<label class="pref" for="chkEnableSponsorblock">
|
|
|
|
<strong v-t="'actions.enable_sponsorblock'" />
|
|
|
|
<input
|
|
|
|
id="chkEnableSponsorblock"
|
|
|
|
v-model="sponsorBlock"
|
|
|
|
class="checkbox"
|
|
|
|
type="checkbox"
|
|
|
|
@change="onChange($event)"
|
|
|
|
/>
|
|
|
|
</label>
|
|
|
|
<label class="pref" for="chkSkipSponsors">
|
|
|
|
<strong v-t="'actions.skip_sponsors'" />
|
|
|
|
<input id="chkSkipSponsors" v-model="skipSponsor" class="checkbox" type="checkbox" @change="onChange($event)" />
|
|
|
|
</label>
|
|
|
|
<label class="pref" for="chkSkipIntro">
|
|
|
|
<strong v-t="'actions.skip_intro'" />
|
|
|
|
<input id="chkSkipIntro" v-model="skipIntro" class="checkbox" type="checkbox" @change="onChange($event)" />
|
|
|
|
</label>
|
|
|
|
<label class="pref" for="chkSkipOutro">
|
|
|
|
<strong v-t="'actions.skip_outro'" />
|
|
|
|
<input id="chkSkipOutro" v-model="skipOutro" class="checkbox" type="checkbox" @change="onChange($event)" />
|
|
|
|
</label>
|
|
|
|
<label class="pref" for="chkSkipPreview">
|
|
|
|
<strong v-t="'actions.skip_preview'" />
|
|
|
|
<input id="chkSkipPreview" v-model="skipPreview" class="checkbox" type="checkbox" @change="onChange($event)" />
|
|
|
|
</label>
|
|
|
|
<label class="pref" for="chkSkipInteraction">
|
|
|
|
<strong v-t="'actions.skip_interaction'" />
|
|
|
|
<input
|
|
|
|
id="chkSkipInteraction"
|
|
|
|
v-model="skipInteraction"
|
|
|
|
class="checkbox"
|
|
|
|
type="checkbox"
|
|
|
|
@change="onChange($event)"
|
|
|
|
/>
|
|
|
|
</label>
|
|
|
|
<label class="pref" for="chkSkipSelfPromo">
|
|
|
|
<strong v-t="'actions.skip_self_promo'" />
|
|
|
|
<input
|
|
|
|
id="chkSkipSelfPromo"
|
|
|
|
v-model="skipSelfPromo"
|
|
|
|
class="checkbox"
|
|
|
|
type="checkbox"
|
|
|
|
@change="onChange($event)"
|
|
|
|
/>
|
|
|
|
</label>
|
|
|
|
<label class="pref" for="chkSkipNonMusic">
|
|
|
|
<strong v-t="'actions.skip_non_music'" />
|
|
|
|
<input
|
|
|
|
id="chkSkipNonMusic"
|
|
|
|
v-model="skipMusicOffTopic"
|
|
|
|
class="checkbox"
|
|
|
|
type="checkbox"
|
|
|
|
@change="onChange($event)"
|
|
|
|
/>
|
|
|
|
</label>
|
|
|
|
<label class="pref" for="chkSkipHighlight">
|
|
|
|
<strong v-t="'actions.skip_highlight'" />
|
|
|
|
<input
|
|
|
|
id="chkSkipHighlight"
|
|
|
|
v-model="skipHighlight"
|
|
|
|
class="checkbox"
|
|
|
|
type="checkbox"
|
|
|
|
@change="onChange($event)"
|
|
|
|
/>
|
|
|
|
</label>
|
|
|
|
<label class="pref" for="chkSkipFiller">
|
|
|
|
<strong v-t="'actions.skip_filler_tangent'" />
|
|
|
|
<input id="chkSkipFiller" v-model="skipFiller" class="checkbox" type="checkbox" @change="onChange($event)" />
|
|
|
|
</label>
|
|
|
|
<label class="pref" for="chkShowMarkers">
|
|
|
|
<strong v-t="'actions.show_markers'" />
|
|
|
|
<input id="chkShowMarkers" v-model="showMarkers" class="checkbox" type="checkbox" @change="onChange($event)" />
|
|
|
|
</label>
|
|
|
|
|
2022-08-15 00:01:09 +05:30
|
|
|
<h2 class="text-center" v-t="'titles.instance'" />
|
2022-08-11 22:42:08 +05:30
|
|
|
<label class="pref" for="ddlInstanceSelection">
|
|
|
|
<strong v-text="`${$t('actions.instance_selection')}:`" />
|
|
|
|
<select id="ddlInstanceSelection" v-model="selectedInstance" class="select w-auto" @change="onChange($event)">
|
|
|
|
<option
|
|
|
|
v-for="instance in instances"
|
|
|
|
:key="instance.name"
|
|
|
|
:value="instance.api_url"
|
|
|
|
v-text="instance.name"
|
|
|
|
/>
|
|
|
|
</select>
|
|
|
|
</label>
|
|
|
|
<label class="pref" for="chkAuthInstance">
|
|
|
|
<strong v-text="`${$t('actions.different_auth_instance')}:`" />
|
|
|
|
<input
|
|
|
|
id="chkAuthInstance"
|
|
|
|
v-model="authInstance"
|
|
|
|
class="checkbox"
|
|
|
|
type="checkbox"
|
|
|
|
@change="onChange($event)"
|
|
|
|
/>
|
|
|
|
</label>
|
|
|
|
<template v-if="authInstance">
|
|
|
|
<label class="pref" for="ddlAuthInstanceSelection">
|
|
|
|
<strong v-text="`${$t('actions.instance_auth_selection')}:`" />
|
|
|
|
<select
|
|
|
|
id="ddlAuthInstanceSelection"
|
|
|
|
v-model="selectedAuthInstance"
|
|
|
|
class="select w-auto"
|
|
|
|
@change="onChange($event)"
|
|
|
|
>
|
|
|
|
<option
|
|
|
|
v-for="instance in instances"
|
|
|
|
:key="instance.name"
|
|
|
|
:value="instance.api_url"
|
|
|
|
v-text="instance.name"
|
|
|
|
/>
|
|
|
|
</select>
|
|
|
|
</label>
|
|
|
|
</template>
|
2021-09-02 19:16:27 +05:30
|
|
|
<br />
|
2022-08-11 22:42:08 +05:30
|
|
|
|
|
|
|
<!-- options that are visible only when logged in -->
|
|
|
|
<div v-if="this.authenticated">
|
2022-08-15 00:01:09 +05:30
|
|
|
<h2 class="text-center" v-t="'titles.account'"></h2>
|
2022-08-11 22:42:08 +05:30
|
|
|
<label class="pref" for="txtDeleteAccountPassword">
|
|
|
|
<strong v-t="'actions.delete_account'" />
|
|
|
|
<div class="flex items-center">
|
|
|
|
<input
|
|
|
|
id="txtDeleteAccountPassword"
|
|
|
|
ref="txtDeleteAccountPassword"
|
|
|
|
v-model="password"
|
|
|
|
v-on:keyup.enter="deleteAccount"
|
|
|
|
:placeholder="$t('login.password')"
|
|
|
|
:aria-label="$t('login.password')"
|
2022-08-11 22:53:18 +05:30
|
|
|
class="input w-auto mr-2"
|
2022-08-11 22:42:08 +05:30
|
|
|
type="password"
|
|
|
|
/>
|
|
|
|
<a class="btn w-auto" @click="deleteAccount" v-t="'actions.delete_account'" />
|
|
|
|
</div>
|
|
|
|
</label>
|
|
|
|
<div class="pref">
|
|
|
|
<a class="btn w-auto" @click="logout" v-t="'actions.logout'" />
|
|
|
|
<a
|
|
|
|
class="btn w-auto"
|
|
|
|
style="margin-left: 0.5em"
|
|
|
|
@click="invalidateSession"
|
|
|
|
v-t="'actions.invalidate_session'"
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
<br />
|
|
|
|
</div>
|
2022-05-28 09:15:13 +05:30
|
|
|
<h2 id="instancesList" v-t="'actions.instances_list'" />
|
2022-01-12 16:57:08 +05:30
|
|
|
<table class="table">
|
2020-11-17 10:45:35 +05:30
|
|
|
<thead>
|
|
|
|
<tr>
|
2022-01-31 05:18:27 +05:30
|
|
|
<th v-t="'preferences.instance_name'" />
|
|
|
|
<th v-t="'preferences.instance_locations'" />
|
|
|
|
<th v-t="'preferences.has_cdn'" />
|
2022-02-23 18:08:21 +05:30
|
|
|
<th v-t="'preferences.registered_users'" />
|
2022-08-17 19:04:57 +05:30
|
|
|
<th class="lt-md:hidden" v-t="'preferences.version'" />
|
2022-02-23 18:08:21 +05:30
|
|
|
<th v-t="'preferences.up_to_date'" />
|
2022-01-31 05:18:27 +05:30
|
|
|
<th v-t="'preferences.ssl_score'" />
|
2020-11-17 10:45:35 +05:30
|
|
|
</tr>
|
|
|
|
</thead>
|
2021-10-09 00:22:51 +05:30
|
|
|
<tbody v-for="instance in instances" :key="instance.name">
|
2020-11-17 10:45:35 +05:30
|
|
|
<tr>
|
2021-12-27 21:59:25 +05:30
|
|
|
<td v-text="instance.name" />
|
|
|
|
<td v-text="instance.locations" />
|
2022-08-13 17:12:35 +05:30
|
|
|
<td v-text="`${instance.cdn ? '✅' : '❌'}`" />
|
2022-02-23 18:08:21 +05:30
|
|
|
<td v-text="instance.registered" />
|
2022-08-17 19:04:57 +05:30
|
|
|
<td class="lt-md:hidden" v-text="instance.version" />
|
2022-08-13 17:12:35 +05:30
|
|
|
<td v-text="`${instance.up_to_date ? '✅' : '❌'}`" />
|
2020-11-30 12:09:40 +05:30
|
|
|
<td>
|
2022-02-23 18:08:21 +05:30
|
|
|
<a :href="sslScore(instance.api_url)" target="_blank" v-t="'actions.view_ssl_score'" />
|
2020-11-30 12:09:40 +05:30
|
|
|
</td>
|
2020-11-17 10:45:35 +05:30
|
|
|
</tr>
|
|
|
|
</tbody>
|
|
|
|
</table>
|
2022-08-11 23:04:35 +05:30
|
|
|
<br />
|
2022-08-22 17:21:44 +05:30
|
|
|
<p v-t="'info.preferences_note'" />
|
2022-08-11 23:04:35 +05:30
|
|
|
<br />
|
2022-08-13 17:12:35 +05:30
|
|
|
<button class="btn" v-t="'actions.reset_preferences'" @click="resetPreferences()" />
|
|
|
|
<button class="btn mx-4" v-t="'actions.backup_preferences'" @click="backupPreferences()" />
|
2022-08-15 00:01:09 +05:30
|
|
|
<label for="fileSelector" class="btn" v-t="'actions.restore_preferences'" @click="restorePreferences()" />
|
2022-08-13 14:59:31 +05:30
|
|
|
<input class="hidden" id="fileSelector" ref="fileSelector" type="file" @change="restorePreferences()" />
|
2020-11-17 10:45:35 +05:30
|
|
|
</template>
|
|
|
|
|
|
|
|
<script>
|
2021-09-22 01:54:21 +05:30
|
|
|
import CountryMap from "@/utils/CountryMaps/en.json";
|
2020-11-17 10:45:35 +05:30
|
|
|
export default {
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
selectedInstance: null,
|
2022-07-21 09:34:57 +05:30
|
|
|
authInstance: false,
|
|
|
|
selectedAuthInstance: null,
|
2021-02-25 20:10:40 +05:30
|
|
|
instances: [],
|
2021-02-25 20:48:59 +05:30
|
|
|
sponsorBlock: true,
|
|
|
|
skipSponsor: true,
|
|
|
|
skipIntro: false,
|
|
|
|
skipOutro: false,
|
2021-07-19 01:23:17 +05:30
|
|
|
skipPreview: false,
|
2021-02-25 20:48:59 +05:30
|
|
|
skipInteraction: true,
|
|
|
|
skipSelfPromo: true,
|
2021-04-07 17:15:40 +05:30
|
|
|
skipMusicOffTopic: true,
|
2022-01-13 15:12:21 +05:30
|
|
|
skipHighlight: false,
|
|
|
|
skipFiller: false,
|
2022-06-06 07:48:47 +05:30
|
|
|
showMarkers: true,
|
2021-06-29 01:15:03 +05:30
|
|
|
selectedTheme: "dark",
|
2021-05-06 23:00:02 +05:30
|
|
|
autoPlayVideo: true,
|
2021-07-04 00:54:09 +05:30
|
|
|
listen: false,
|
2021-06-22 01:55:38 +05:30
|
|
|
resolutions: [144, 240, 360, 480, 720, 1080, 1440, 2160, 4320],
|
2021-06-22 01:33:11 +05:30
|
|
|
defaultQuality: 0,
|
2021-06-22 16:24:20 +05:30
|
|
|
bufferingGoal: 10,
|
2021-09-22 01:54:21 +05:30
|
|
|
countryMap: CountryMap,
|
2021-10-09 00:22:51 +05:30
|
|
|
countrySelected: "US",
|
2021-07-19 01:50:35 +05:30
|
|
|
defaultHomepage: "trending",
|
2022-10-24 04:49:57 +05:30
|
|
|
minimizeComments: false,
|
2021-07-30 14:33:16 +05:30
|
|
|
minimizeDescription: false,
|
2022-07-20 01:26:16 +05:30
|
|
|
minimizeRecommendations: false,
|
2022-11-02 21:40:27 +05:30
|
|
|
showWatchOnYouTube: false,
|
2021-08-22 15:57:09 +05:30
|
|
|
watchHistory: false,
|
2022-09-11 23:31:58 +05:30
|
|
|
searchHistory: false,
|
2022-09-10 22:38:50 +05:30
|
|
|
hideWatched: false,
|
2021-08-25 22:00:21 +05:30
|
|
|
selectedLanguage: "en",
|
|
|
|
languages: [
|
2022-06-16 20:25:08 +05:30
|
|
|
{ code: "ar", name: "Arabic" },
|
2022-06-03 00:16:52 +05:30
|
|
|
{ code: "az", name: "Azərbaycan" },
|
2021-09-06 12:38:15 +05:30
|
|
|
{ code: "bn", name: "বাংলা" },
|
2022-04-09 05:38:54 +05:30
|
|
|
{ code: "bs", name: "Bosanski" },
|
2022-02-15 16:27:37 +05:30
|
|
|
{ code: "ca", name: "Català" },
|
2021-12-27 16:45:23 +05:30
|
|
|
{ code: "cs", name: "Čeština" },
|
2022-03-21 00:06:05 +05:30
|
|
|
{ code: "da", name: "Dansk" },
|
2021-09-06 12:38:15 +05:30
|
|
|
{ code: "de", name: "Deutsch" },
|
|
|
|
{ code: "el", name: "Ελληνικά" },
|
2021-09-16 23:49:37 +05:30
|
|
|
{ code: "es", name: "Español" },
|
|
|
|
{ code: "en", name: "English" },
|
2022-02-15 16:27:37 +05:30
|
|
|
{ code: "eo", name: "Esperanto" },
|
2022-06-03 00:16:52 +05:30
|
|
|
{ code: "et", name: "Eesti" },
|
2021-09-16 23:49:37 +05:30
|
|
|
{ code: "fa", name: "فارسی" },
|
2021-09-24 04:07:40 +05:30
|
|
|
{ code: "fi", name: "Suomi" },
|
2022-03-14 20:28:05 +05:30
|
|
|
{ code: "fr", name: "Français" },
|
2022-09-11 13:07:14 +05:30
|
|
|
{ code: "he", name: "עברית" },
|
2022-01-16 14:12:01 +05:30
|
|
|
{ code: "hi", name: "हिंदी" },
|
2021-12-09 20:13:53 +05:30
|
|
|
{ code: "id", name: "Indonesia" },
|
|
|
|
{ code: "is", name: "Íslenska" },
|
2021-09-16 23:59:48 +05:30
|
|
|
{ code: "hr", name: "Hrvatski" },
|
2022-03-14 20:28:05 +05:30
|
|
|
{ code: "it", name: "Italiano" },
|
2021-11-12 19:31:07 +05:30
|
|
|
{ code: "ja", name: "日本語" },
|
2021-12-24 16:17:32 +05:30
|
|
|
{ code: "ko", name: "한국어" },
|
2022-03-14 20:28:05 +05:30
|
|
|
{ code: "lt", name: "Lietuvių kalba" },
|
2021-09-06 12:38:15 +05:30
|
|
|
{ code: "ml", name: "മലയാളം" },
|
2021-08-26 17:18:23 +05:30
|
|
|
{ code: "nb_NO", name: "Norwegian Bokmål" },
|
2022-04-09 05:38:54 +05:30
|
|
|
{ code: "nl", name: "Nederlands" },
|
2022-11-07 07:03:58 +05:30
|
|
|
{ code: "or", name: "ଓଡ଼ିଆ" },
|
2022-03-14 20:28:05 +05:30
|
|
|
{ code: "pl", name: "Polski" },
|
2021-12-24 16:17:32 +05:30
|
|
|
{ code: "pt", name: "Português" },
|
2022-03-14 20:31:01 +05:30
|
|
|
{ code: "pt_PT", name: "Português (Portugal)" },
|
2022-06-16 20:25:08 +05:30
|
|
|
{ code: "pt_BR", name: "Português (Brasil)" },
|
2022-03-14 20:28:05 +05:30
|
|
|
{ code: "ru", name: "Русский" },
|
2021-11-25 01:01:39 +05:30
|
|
|
{ code: "sr", name: "Српски" },
|
2022-03-14 20:28:05 +05:30
|
|
|
{ code: "sv", name: "Svenska" },
|
2022-01-16 14:12:01 +05:30
|
|
|
{ code: "ta", name: "தமிழ்" },
|
2022-01-20 02:21:31 +05:30
|
|
|
{ code: "th", name: "ไทย" },
|
2021-09-06 12:38:15 +05:30
|
|
|
{ code: "tr", name: "Türkçe" },
|
2022-03-14 20:28:05 +05:30
|
|
|
{ code: "uk", name: "Українська" },
|
2022-04-07 08:04:48 +05:30
|
|
|
{ code: "vi", name: "Tiếng Việt" },
|
2021-09-16 23:59:48 +05:30
|
|
|
{ code: "zh_Hant", name: "繁體中文" },
|
2021-09-24 04:07:40 +05:30
|
|
|
{ code: "zh_Hans", name: "简体中文" },
|
2021-08-25 22:00:21 +05:30
|
|
|
],
|
2022-06-06 10:25:01 +05:30
|
|
|
enabledCodecs: ["vp9", "avc"],
|
2021-09-02 19:16:27 +05:30
|
|
|
disableLBRY: false,
|
|
|
|
proxyLBRY: false,
|
2022-07-20 19:45:27 +05:30
|
|
|
password: null,
|
2020-11-17 10:45:35 +05:30
|
|
|
};
|
|
|
|
},
|
2021-07-21 16:29:53 +05:30
|
|
|
activated() {
|
2021-08-25 22:00:21 +05:30
|
|
|
document.title = this.$t("titles.preferences") + " - Piped";
|
2021-07-21 16:29:53 +05:30
|
|
|
},
|
2021-09-22 01:54:21 +05:30
|
|
|
async mounted() {
|
2021-07-04 00:54:09 +05:30
|
|
|
if (Object.keys(this.$route.query).length > 0) this.$router.replace({ query: {} });
|
|
|
|
|
2022-02-23 18:08:21 +05:30
|
|
|
this.fetchJson("https://piped-instances.kavin.rocks/").then(resp => {
|
|
|
|
this.instances = resp;
|
|
|
|
if (this.instances.filter(instance => instance.api_url == this.apiUrl()).length == 0)
|
|
|
|
this.instances.push({
|
|
|
|
name: "Custom Instance",
|
|
|
|
api_url: this.apiUrl(),
|
|
|
|
locations: "Unknown",
|
|
|
|
cdn: false,
|
2020-11-17 10:45:35 +05:30
|
|
|
});
|
2022-02-23 18:08:21 +05:30
|
|
|
});
|
2020-11-17 10:45:35 +05:30
|
|
|
|
2021-08-28 17:30:17 +05:30
|
|
|
if (this.testLocalStorage) {
|
2021-07-05 18:48:54 +05:30
|
|
|
this.selectedInstance = this.getPreferenceString("instance", "https://pipedapi.kavin.rocks");
|
2022-07-21 09:34:57 +05:30
|
|
|
this.authInstance = this.getPreferenceBoolean("authInstance", false);
|
|
|
|
this.selectedAuthInstance = this.getPreferenceString("auth_instance_url", this.selectedInstance);
|
2021-02-25 20:10:40 +05:30
|
|
|
|
2021-07-04 00:54:09 +05:30
|
|
|
this.sponsorBlock = this.getPreferenceBoolean("sponsorblock", true);
|
2021-04-21 19:08:50 +05:30
|
|
|
if (localStorage.getItem("selectedSkip") !== null) {
|
2021-02-25 20:48:59 +05:30
|
|
|
var skipList = localStorage.getItem("selectedSkip").split(",");
|
2021-12-27 20:13:37 +05:30
|
|
|
this.skipSponsor =
|
|
|
|
this.skipIntro =
|
|
|
|
this.skipOutro =
|
|
|
|
this.skipPreview =
|
|
|
|
this.skipInteraction =
|
|
|
|
this.skipSelfPromo =
|
|
|
|
this.skipMusicOffTopic =
|
2022-01-13 15:12:21 +05:30
|
|
|
this.skipHighlight =
|
|
|
|
this.skipFiller =
|
2021-12-27 20:13:37 +05:30
|
|
|
false;
|
2021-02-25 20:48:59 +05:30
|
|
|
skipList.forEach(skip => {
|
|
|
|
switch (skip) {
|
|
|
|
case "sponsor":
|
|
|
|
this.skipSponsor = true;
|
|
|
|
break;
|
|
|
|
case "intro":
|
|
|
|
this.skipIntro = true;
|
|
|
|
break;
|
|
|
|
case "outro":
|
|
|
|
this.skipOutro = true;
|
|
|
|
break;
|
2021-07-19 01:23:17 +05:30
|
|
|
case "preview":
|
|
|
|
this.skipPreview = true;
|
|
|
|
break;
|
2021-02-25 20:48:59 +05:30
|
|
|
case "interaction":
|
|
|
|
this.skipInteraction = true;
|
|
|
|
break;
|
|
|
|
case "selfpromo":
|
|
|
|
this.skipSelfPromo = true;
|
|
|
|
break;
|
|
|
|
case "music_offtopic":
|
|
|
|
this.skipMusicOffTopic = true;
|
|
|
|
break;
|
2022-01-13 15:12:21 +05:30
|
|
|
case "poi_highlight":
|
|
|
|
this.skipHighlight = true;
|
|
|
|
break;
|
|
|
|
case "filler":
|
|
|
|
this.skipFiller = true;
|
|
|
|
break;
|
2021-02-25 20:48:59 +05:30
|
|
|
default:
|
|
|
|
console.log("Unknown sponsor type: " + skip);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
2021-05-06 23:00:02 +05:30
|
|
|
|
2022-06-06 07:48:47 +05:30
|
|
|
this.showMarkers = this.getPreferenceBoolean("showMarkers", true);
|
2021-07-04 00:54:09 +05:30
|
|
|
this.selectedTheme = this.getPreferenceString("theme", "dark");
|
2021-09-18 02:04:51 +05:30
|
|
|
this.autoPlayVideo = this.getPreferenceBoolean("playerAutoPlay", true);
|
2021-07-04 00:54:09 +05:30
|
|
|
this.listen = this.getPreferenceBoolean("listen", false);
|
2021-06-22 01:33:11 +05:30
|
|
|
this.defaultQuality = Number(localStorage.getItem("quality"));
|
2021-06-22 16:24:20 +05:30
|
|
|
this.bufferingGoal = Math.max(Number(localStorage.getItem("bufferGoal")), 10);
|
2021-10-09 00:22:51 +05:30
|
|
|
this.countrySelected = this.getPreferenceString("region", "US");
|
2021-07-19 01:50:35 +05:30
|
|
|
this.defaultHomepage = this.getPreferenceString("homepage", "trending");
|
2022-10-24 15:19:29 +05:30
|
|
|
this.minimizeComments = this.getPreferenceBoolean("minimizeComments", false);
|
2021-07-30 14:33:16 +05:30
|
|
|
this.minimizeDescription = this.getPreferenceBoolean("minimizeDescription", false);
|
2022-07-20 01:26:16 +05:30
|
|
|
this.minimizeRecommendations = this.getPreferenceBoolean("minimizeRecommendations", false);
|
2022-11-02 21:40:27 +05:30
|
|
|
this.showWatchOnYouTube = this.getPreferenceBoolean("showWatchOnYouTube", false);
|
2021-08-22 15:57:09 +05:30
|
|
|
this.watchHistory = this.getPreferenceBoolean("watchHistory", false);
|
2022-09-11 23:31:58 +05:30
|
|
|
this.searchHistory = this.getPreferenceBoolean("searchHistory", false);
|
2022-11-03 22:15:28 +05:30
|
|
|
this.selectedLanguage = this.getPreferenceString("hl", await this.defaultLanguage);
|
2022-06-06 10:25:01 +05:30
|
|
|
this.enabledCodecs = this.getPreferenceString("enabledCodecs", "vp9,avc").split(",");
|
2021-09-02 19:16:27 +05:30
|
|
|
this.disableLBRY = this.getPreferenceBoolean("disableLBRY", false);
|
|
|
|
this.proxyLBRY = this.getPreferenceBoolean("proxyLBRY", false);
|
2022-09-10 22:38:50 +05:30
|
|
|
this.hideWatched = this.getPreferenceBoolean("hideWatched", false);
|
2021-09-22 01:54:21 +05:30
|
|
|
if (this.selectedLanguage != "en") {
|
|
|
|
try {
|
2021-12-28 20:09:20 +05:30
|
|
|
this.CountryMap = await import(`../utils/CountryMaps/${this.selectedLanguage}.json`).then(
|
|
|
|
val => val.default,
|
2021-09-24 04:07:40 +05:30
|
|
|
);
|
2021-09-22 01:54:21 +05:30
|
|
|
} catch (e) {
|
|
|
|
console.error("Countries not translated into " + this.selectedLanguage);
|
|
|
|
}
|
|
|
|
}
|
2021-02-25 20:10:40 +05:30
|
|
|
}
|
2020-11-17 10:45:35 +05:30
|
|
|
},
|
|
|
|
methods: {
|
2022-06-26 07:23:06 +05:30
|
|
|
async onChange() {
|
2021-08-28 17:30:17 +05:30
|
|
|
if (this.testLocalStorage) {
|
2021-06-29 01:15:03 +05:30
|
|
|
var shouldReload = false;
|
|
|
|
|
2021-08-22 15:57:09 +05:30
|
|
|
if (
|
|
|
|
this.getPreferenceString("theme", "dark") !== this.selectedTheme ||
|
2021-08-25 22:00:21 +05:30
|
|
|
this.getPreferenceBoolean("watchHistory", false) != this.watchHistory ||
|
2022-11-03 22:15:28 +05:30
|
|
|
this.getPreferenceString("hl", await this.defaultLanguage) !== this.selectedLanguage ||
|
2022-11-06 06:14:27 +05:30
|
|
|
this.getPreferenceString("enabledCodecs", "vp9,avc") !== this.enabledCodecs.join(",")
|
2021-08-22 15:57:09 +05:30
|
|
|
)
|
|
|
|
shouldReload = true;
|
2021-06-29 01:15:03 +05:30
|
|
|
|
2020-11-17 10:45:35 +05:30
|
|
|
localStorage.setItem("instance", this.selectedInstance);
|
2022-07-21 09:34:57 +05:30
|
|
|
localStorage.setItem("authInstance", this.authInstance);
|
|
|
|
localStorage.setItem("auth_instance_url", this.selectedAuthInstance);
|
2021-02-25 20:10:40 +05:30
|
|
|
localStorage.setItem("sponsorblock", this.sponsorBlock);
|
2021-02-25 20:48:59 +05:30
|
|
|
|
|
|
|
var sponsorSelected = [];
|
|
|
|
if (this.skipSponsor) sponsorSelected.push("sponsor");
|
|
|
|
if (this.skipIntro) sponsorSelected.push("intro");
|
|
|
|
if (this.skipOutro) sponsorSelected.push("outro");
|
2021-07-19 01:23:17 +05:30
|
|
|
if (this.skipPreview) sponsorSelected.push("preview");
|
2021-02-25 20:48:59 +05:30
|
|
|
if (this.skipInteraction) sponsorSelected.push("interaction");
|
|
|
|
if (this.skipSelfPromo) sponsorSelected.push("selfpromo");
|
2021-04-07 17:15:40 +05:30
|
|
|
if (this.skipMusicOffTopic) sponsorSelected.push("music_offtopic");
|
2022-01-13 15:12:21 +05:30
|
|
|
if (this.skipHighlight) sponsorSelected.push("poi_highlight");
|
|
|
|
if (this.skipFiller) sponsorSelected.push("filler");
|
2021-02-25 20:48:59 +05:30
|
|
|
localStorage.setItem("selectedSkip", sponsorSelected);
|
2021-05-06 23:00:02 +05:30
|
|
|
|
2022-06-06 07:48:47 +05:30
|
|
|
localStorage.setItem("showMarkers", this.showMarkers);
|
2021-06-29 01:15:03 +05:30
|
|
|
localStorage.setItem("theme", this.selectedTheme);
|
2021-05-06 23:00:02 +05:30
|
|
|
localStorage.setItem("playerAutoPlay", this.autoPlayVideo);
|
2021-07-04 00:54:09 +05:30
|
|
|
localStorage.setItem("listen", this.listen);
|
2021-06-22 01:33:11 +05:30
|
|
|
localStorage.setItem("quality", this.defaultQuality);
|
2021-06-22 16:24:20 +05:30
|
|
|
localStorage.setItem("bufferGoal", this.bufferingGoal);
|
2021-10-09 00:22:51 +05:30
|
|
|
localStorage.setItem("region", this.countrySelected);
|
2021-07-19 01:50:35 +05:30
|
|
|
localStorage.setItem("homepage", this.defaultHomepage);
|
2022-10-24 04:49:57 +05:30
|
|
|
localStorage.setItem("minimizeComments", this.minimizeComments);
|
2021-07-30 14:33:16 +05:30
|
|
|
localStorage.setItem("minimizeDescription", this.minimizeDescription);
|
2022-07-20 01:26:16 +05:30
|
|
|
localStorage.setItem("minimizeRecommendations", this.minimizeRecommendations);
|
2022-11-02 21:40:27 +05:30
|
|
|
localStorage.setItem("showWatchOnYouTube", this.showWatchOnYouTube);
|
2021-08-22 15:57:09 +05:30
|
|
|
localStorage.setItem("watchHistory", this.watchHistory);
|
2022-09-11 23:31:58 +05:30
|
|
|
localStorage.setItem("searchHistory", this.searchHistory);
|
2022-10-02 18:59:23 +05:30
|
|
|
if (!this.searchHistory) localStorage.removeItem("search_history");
|
2021-08-25 22:00:21 +05:30
|
|
|
localStorage.setItem("hl", this.selectedLanguage);
|
2021-08-27 13:03:55 +05:30
|
|
|
localStorage.setItem("enabledCodecs", this.enabledCodecs.join(","));
|
2021-09-02 19:16:27 +05:30
|
|
|
localStorage.setItem("disableLBRY", this.disableLBRY);
|
|
|
|
localStorage.setItem("proxyLBRY", this.proxyLBRY);
|
2022-09-10 22:38:50 +05:30
|
|
|
localStorage.setItem("hideWatched", this.hideWatched);
|
2021-06-29 01:15:03 +05:30
|
|
|
|
|
|
|
if (shouldReload) window.location.reload();
|
2021-02-25 20:10:40 +05:30
|
|
|
}
|
2020-11-30 12:09:40 +05:30
|
|
|
},
|
|
|
|
sslScore(url) {
|
2021-04-07 17:15:40 +05:30
|
|
|
return "https://www.ssllabs.com/ssltest/analyze.html?d=" + new URL(url).host + "&latest";
|
|
|
|
},
|
2022-07-20 19:45:27 +05:30
|
|
|
async deleteAccount() {
|
2022-07-21 09:34:57 +05:30
|
|
|
this.fetchJson(this.authApiUrl() + "/user/delete", null, {
|
2022-07-20 19:45:27 +05:30
|
|
|
method: "POST",
|
|
|
|
headers: {
|
|
|
|
Authorization: this.getAuthToken(),
|
|
|
|
},
|
|
|
|
body: JSON.stringify({
|
|
|
|
password: this.password,
|
|
|
|
}),
|
|
|
|
}).then(resp => {
|
|
|
|
if (!resp.error) {
|
|
|
|
this.logout();
|
|
|
|
} else alert(resp.error);
|
|
|
|
});
|
|
|
|
},
|
|
|
|
logout() {
|
|
|
|
// reset the auth token
|
2022-07-21 09:34:57 +05:30
|
|
|
localStorage.removeItem("authToken" + this.hashCode(this.authApiUrl()));
|
2022-07-20 19:45:27 +05:30
|
|
|
// redirect to trending page
|
|
|
|
window.location = "/";
|
|
|
|
},
|
2022-08-11 23:11:07 +05:30
|
|
|
resetPreferences() {
|
2022-08-15 00:01:09 +05:30
|
|
|
if (!confirm(this.$t("actions.confirm_reset_preferences"))) return;
|
2022-08-11 23:11:07 +05:30
|
|
|
// clear the local storage
|
|
|
|
localStorage.clear();
|
|
|
|
// redirect to the home page
|
|
|
|
window.location = "/";
|
|
|
|
},
|
2022-07-20 21:51:11 +05:30
|
|
|
async invalidateSession() {
|
2022-07-21 09:34:57 +05:30
|
|
|
this.fetchJson(this.authApiUrl() + "/logout", null, {
|
2022-07-20 21:51:11 +05:30
|
|
|
method: "POST",
|
|
|
|
headers: {
|
|
|
|
Authorization: this.getAuthToken(),
|
|
|
|
},
|
|
|
|
}).then(resp => {
|
|
|
|
if (!resp.error) {
|
|
|
|
this.logout();
|
|
|
|
} else alert(resp.error);
|
|
|
|
});
|
|
|
|
},
|
2022-08-13 14:59:31 +05:30
|
|
|
backupPreferences() {
|
|
|
|
const data = JSON.stringify(localStorage);
|
|
|
|
this.download(data, "preferences.json", "application/json");
|
|
|
|
},
|
|
|
|
restorePreferences() {
|
|
|
|
var file = this.$refs.fileSelector.files[0];
|
|
|
|
file.text().then(text => {
|
|
|
|
const data = JSON.parse(text);
|
|
|
|
Object.keys(data).forEach(function (key) {
|
|
|
|
localStorage.setItem(key, data[key]);
|
|
|
|
});
|
|
|
|
window.location.reload();
|
|
|
|
});
|
|
|
|
},
|
2021-04-07 17:15:40 +05:30
|
|
|
},
|
2020-11-17 10:45:35 +05:30
|
|
|
};
|
|
|
|
</script>
|
2022-08-11 22:42:08 +05:30
|
|
|
|
|
|
|
<style>
|
|
|
|
.pref {
|
2022-08-17 19:04:57 +05:30
|
|
|
@apply flex justify-between items-center my-2 mx-[15vw] lt-md:mx-[2vw];
|
2022-08-11 22:42:08 +05:30
|
|
|
}
|
|
|
|
</style>
|