mirror of
https://github.com/MrUnknownDE/VRCX.git
synced 2026-04-23 08:43:50 +02:00
* refactor: frontend * Fix avatar gallery sort * Update .NET dependencies * Update npm dependencies electron v37.1.0 * bulkRefreshFriends * fix dark theme * Remove crowdin * Fix config.json dialog not updating * VRCX log file fixes & add Cef log * Remove SharedVariable, fix startup * Revert init theme change * Logging date not working? Fix WinformThemer designer error * Add Cef request hander, no more escaping main page * clean * fix * fix * clean * uh * Apply thememode at startup, fixes random user colours * Split database into files * Instance info remove empty lines * Open external VRC links with VRCX * Electron fixes * fix userdialog style * ohhhh * fix store * fix store * fix: load all group members after kicking a user * fix: world dialog favorite button style * fix: Clear VRCX Cache Timer input value * clean * Fix VR overlay * Fix VR overlay 2 * Fix Discord discord rich presence for RPC worlds * Clean up age verified user tags * Fix playerList being occupied after program reload * no `this` * Fix login stuck loading * writable: false * Hide dialogs on logout * add flush sync option * rm LOGIN event * rm LOGOUT event * remove duplicate event listeners * remove duplicate event listeners * clean * remove duplicate event listeners * clean * fix theme style * fix t * clearable * clean * fix ipcEvent * Small changes * Popcorn Palace support * Remove checkActiveFriends * Clean up * Fix dragEnterCef * Block API requests when not logged in * Clear state on login & logout * Fix worldDialog instances not updating * use <script setup> * Fix avatar change event, CheckGameRunning at startup * Fix image dragging * fix * Remove PWI * fix updateLoop * add webpack-dev-server to dev environment * rm unnecessary chunks * use <script setup> * webpack-dev-server changes * use <script setup> * use <script setup> * Fix UGC text size * Split login event * t * use <script setup> * fix * Update .gitignore and enable checkJs in jsconfig * fix i18n t * use <script setup> * use <script setup> * clean * global types * fix * use checkJs for debugging * Add watchState for login watchers * fix .vue template * type fixes * rm Vue.filter * Cef v138.0.170, VC++ 2022 * Settings fixes * Remove 'USER:CURRENT' * clean up 2FA callbacks * remove userApply * rm i18n import * notification handling to use notification store methods * refactor favorite handling to use favorite store methods and clean up event emissions * refactor moderation handling to use dedicated functions for player moderation events * refactor friend handling to use dedicated functions for friend events * Fix program startup, move lang init * Fix friend state * Fix status change error * Fix user notes diff * fix * rm group event * rm auth event * rm avatar event * clean * clean * getUser * getFriends * getFavoriteWorlds, getFavoriteAvatars * AvatarGalleryUpload btn style & package.json update * Fix friend requests * Apply user * Apply world * Fix note diff * Fix VR overlay * Fixes * Update build scripts * Apply avatar * Apply instance * Apply group * update hidden VRC+ badge * Fix sameInstance "private" * fix 502/504 API errors * fix 502/504 API errors * clean * Fix friend in same instance on orange showing twice in friends list * Add back in broken friend state repair methods * add types --------- Co-authored-by: Natsumi <cmcooper123@hotmail.com>
87 lines
2.9 KiB
Vue
87 lines
2.9 KiB
Vue
<template>
|
|
<safe-dialog
|
|
class="x-dialog"
|
|
:visible.sync="languageDialog.visible"
|
|
:title="t('dialog.language.header')"
|
|
width="400px"
|
|
append-to-body>
|
|
<div v-loading="languageDialog.loading">
|
|
<div v-for="item in currentUser.$languages" :key="item.key" style="margin: 6px 0">
|
|
<el-tag
|
|
size="small"
|
|
type="info"
|
|
effect="plain"
|
|
closable
|
|
style="margin-right: 5px"
|
|
@close="removeUserLanguage(item.key)">
|
|
<span
|
|
class="flags"
|
|
:class="languageClass(item.key)"
|
|
style="display: inline-block; margin-right: 5px"></span>
|
|
{{ item.value }} ({{ item.key.toUpperCase() }})
|
|
</el-tag>
|
|
</div>
|
|
<el-select
|
|
value=""
|
|
:disabled="languageDialog.loading || (currentUser.$languages && currentUser.$languages.length === 3)"
|
|
:placeholder="t('dialog.language.select_language')"
|
|
style="margin-top: 14px"
|
|
@change="addUserLanguage">
|
|
<el-option
|
|
v-for="item in languageDialog.languages"
|
|
:key="item.key"
|
|
:value="item.key"
|
|
:label="item.value">
|
|
<span
|
|
class="flags"
|
|
:class="languageClass(item.key)"
|
|
style="display: inline-block; margin-right: 5px"></span>
|
|
{{ item.value }} ({{ item.key.toUpperCase() }})
|
|
</el-option>
|
|
</el-select>
|
|
</div>
|
|
</safe-dialog>
|
|
</template>
|
|
|
|
<script setup>
|
|
import { storeToRefs } from 'pinia';
|
|
import { useI18n } from 'vue-i18n-bridge';
|
|
import { userRequest } from '../../../api';
|
|
import { languageClass } from '../../../shared/utils';
|
|
import { useUserStore } from '../../../stores';
|
|
|
|
const { t } = useI18n();
|
|
|
|
const { languageDialog, currentUser } = storeToRefs(useUserStore());
|
|
|
|
function removeUserLanguage(language) {
|
|
if (language !== String(language)) {
|
|
return;
|
|
}
|
|
const D = languageDialog.value;
|
|
D.loading = true;
|
|
userRequest
|
|
.removeUserTags({
|
|
tags: [`language_${language}`]
|
|
})
|
|
.finally(function () {
|
|
D.loading = false;
|
|
});
|
|
}
|
|
|
|
function addUserLanguage(language) {
|
|
if (language !== String(language)) {
|
|
return;
|
|
}
|
|
const D = languageDialog.value;
|
|
D.loading = true;
|
|
userRequest
|
|
.addUserTags({
|
|
tags: [`language_${language}`]
|
|
})
|
|
.finally(function () {
|
|
D.loading = false;
|
|
});
|
|
}
|
|
</script>
|