fchat-rising/chat/SettingsView.vue

363 lines
16 KiB
Vue
Raw Normal View History

2017-09-02 01:50:31 +00:00
<template>
2019-01-03 17:38:17 +00:00
<modal :action="l('settings.action')" @submit="submit" @open="load()" id="settings" dialogClass="w-100">
2018-04-16 23:14:13 +00:00
<tabs style="flex-shrink:0;margin-bottom:10px" v-model="selectedTab"
2020-10-25 16:55:21 +00:00
:tabs="[l('settings.tabs.general'), l('settings.tabs.notifications'), 'F-Chat Rising 🦄', l('settings.tabs.hideAds'), l('settings.tabs.import')]"></tabs>
2019-01-03 17:38:17 +00:00
<div v-show="selectedTab === '0'">
2017-09-02 01:50:31 +00:00
<div class="form-group">
<label class="control-label" for="disallowedTags">{{l('settings.disallowedTags')}}</label>
<input id="disallowedTags" class="form-control" v-model="disallowedTags"/>
</div>
<div class="form-group">
<label class="control-label" for="clickOpensMessage">
<input type="checkbox" id="clickOpensMessage" v-model="clickOpensMessage"/>
{{l('settings.clickOpensMessage')}}
</label>
</div>
2018-03-28 13:51:05 +00:00
<div class="form-group">
<label class="control-label" for="enterSend">
<input type="checkbox" id="enterSend" v-model="enterSend"/>
{{l('settings.enterSend')}}
</label>
</div>
2017-09-02 01:50:31 +00:00
<div class="form-group">
<label class="control-label" for="showAvatars">
<input type="checkbox" id="showAvatars" v-model="showAvatars"/>
{{l('settings.showAvatars')}}
</label>
</div>
<div class="form-group">
<label class="control-label" for="colorBookmarks">
<input type="checkbox" id="colorBookmarks" v-model="colorBookmarks"/>
{{l('settings.colorBookmarks')}}
</label>
</div>
2017-09-02 01:50:31 +00:00
<div class="form-group">
<label class="control-label" for="animatedEicons">
<input type="checkbox" id="animatedEicons" v-model="animatedEicons"/>
{{l('settings.animatedEicons')}}
</label>
</div>
<div class="form-group">
<label class="control-label" for="idleTimer">{{l('settings.idleTimer')}}</label>
2018-08-10 16:59:37 +00:00
<input id="idleTimer" class="form-control" type="number" v-model="idleTimer" min="0" max="1440"/>
2017-09-02 01:50:31 +00:00
</div>
<div class="form-group">
<label class="control-label" for="messageSeparators">
<input type="checkbox" id="messageSeparators" v-model="messageSeparators"/>
{{l('settings.messageSeparators')}}
</label>
</div>
2018-07-20 01:12:26 +00:00
<div class="form-group">
<label class="control-label" for="bbCodeBar">
<input type="checkbox" id="bbCodeBar" v-model="bbCodeBar"/>
{{l('settings.bbCodeBar')}}
</label>
</div>
2017-09-02 01:50:31 +00:00
<div class="form-group">
<label class="control-label" for="logMessages">
<input type="checkbox" id="logMessages" v-model="logMessages"/>
{{l('settings.logMessages')}}
</label>
</div>
<div class="form-group">
<label class="control-label" for="logAds">
<input type="checkbox" id="logAds" v-model="logAds"/>
{{l('settings.logAds')}}
</label>
</div>
<div class="form-group">
<label class="control-label" for="fontSize">{{l('settings.fontSize')}}</label>
2018-01-06 16:14:21 +00:00
<input id="fontSize" type="number" min="10" max="24" class="form-control" v-model="fontSize"/>
</div>
2017-09-02 01:50:31 +00:00
</div>
2019-01-03 17:38:17 +00:00
<div v-show="selectedTab === '1'">
2017-09-02 01:50:31 +00:00
<div class="form-group">
<label class="control-label" for="playSound">
<input type="checkbox" id="playSound" v-model="playSound"/>
{{l('settings.playSound')}}
</label>
</div>
2018-03-28 13:51:05 +00:00
<div class="form-group">
<label class="control-label" for="alwaysNotify">
<input type="checkbox" id="alwaysNotify" v-model="alwaysNotify" :disabled="!playSound"/>
{{l('settings.alwaysNotify')}}
</label>
</div>
2017-09-02 01:50:31 +00:00
<div class="form-group">
<label class="control-label" for="notifications">
<input type="checkbox" id="notifications" v-model="notifications"/>
{{l('settings.notifications')}}
</label>
</div>
<div class="form-group">
<label class="control-label" for="highlight">
<input type="checkbox" id="highlight" v-model="highlight"/>
{{l('settings.highlight')}}
</label>
</div>
<div class="form-group">
<label class="control-label" for="highlightWords">{{l('settings.highlightWords')}}</label>
<input id="highlightWords" class="form-control" v-model="highlightWords"/>
</div>
<div class="form-group">
<label class="control-label" for="eventMessages">
<input type="checkbox" id="eventMessages" v-model="eventMessages"/>
{{l('settings.eventMessages')}}
</label>
</div>
<div class="form-group">
<label class="control-label" for="joinMessages">
<input type="checkbox" id="joinMessages" v-model="joinMessages"/>
{{l('settings.joinMessages')}}
</label>
</div>
<div class="form-group">
<label class="control-label" for="showNeedsReply">
<input type="checkbox" id="showNeedsReply" v-model="showNeedsReply"/>
{{l('settings.showNeedsReply')}}
</label>
</div>
2017-09-02 01:50:31 +00:00
</div>
2019-01-03 17:38:17 +00:00
<div v-show="selectedTab === '2'">
2020-10-25 16:55:21 +00:00
<h5>Matching</h5>
<div class="form-group">
<label class="control-label" for="risingAdScore">
<input type="checkbox" id="risingAdScore" v-model="risingAdScore"/>
Colorize ads, profiles, and names of compatible and incompatible characters
</label>
2020-10-25 16:55:21 +00:00
</div>
<div class="form-group">
<label class="control-label" for="risingComparisonInUserMenu">
<input type="checkbox" id="risingComparisonInUserMenu" v-model="risingComparisonInUserMenu"/>
Show quick match results in the right click character menu
</label>
</div>
<div class="form-group">
<label class="control-label" for="risingComparisonInSearch">
<input type="checkbox" id="risingComparisonInSearch" v-model="risingComparisonInSearch"/>
Show quick match results in search results
</label>
</div>
<!-- <div class="form-group">-->
<!-- <label class="control-label" for="hideProfileComparisonSummary">-->
<!-- <input type="checkbox" id="hideProfileComparisonSummary" :checked="!hideProfileComparisonSummary" @input="hideProfileComparisonSummary = !$event.target.checked"/>-->
<!-- Show quick match results at the top of the character profile-->
<!-- </label>-->
<!-- </div>-->
2020-10-25 16:55:21 +00:00
<h5>Preview</h5>
<div class="form-group">
<label class="control-label" for="risingLinkPreview">
<input type="checkbox" id="risingLinkPreview" v-model="risingLinkPreview"/>
2020-10-25 16:55:21 +00:00
Show a link/image preview when the mouse hovers over a link
</label>
2020-10-25 16:55:21 +00:00
</div>
2020-10-25 16:55:21 +00:00
<div class="form-group">
<label class="control-label" for="risingCharacterPreview">
<input type="checkbox" id="risingCharacterPreview" v-model="risingCharacterPreview"/>
Show a character preview when mouse hovers over a character name
</label>
</div>
<h5>Profile</h5>
<div class="form-group">
<label class="control-label" for="risingAutoCompareKinks">
<input type="checkbox" id="risingAutoCompareKinks" v-model="risingAutoCompareKinks"/>
Automatically compare kinks when viewing a character profile
</label>
</div>
2020-10-25 16:55:21 +00:00
<div class="form-group">
<label class="control-label" for="risingAutoExpandCustomKinks">
<input type="checkbox" id="risingAutoExpandCustomKinks" v-model="risingAutoExpandCustomKinks"/>
Automatically expand custom kinks
</label>
</div>
2020-11-27 20:58:14 +00:00
<h5>Misc</h5>
<div class="form-group">
<label class="control-label" for="risingShowUnreadOfflineCount">
<input type="checkbox" id="risingShowUnreadOfflineCount" v-model="risingShowUnreadOfflineCount"/>
Show unread note and offline message counts at the bottom right corner
</label>
</div>
</div>
<div v-show="selectedTab === '3'">
2019-01-03 17:38:17 +00:00
<template v-if="hidden.length">
<div v-for="(user, i) in hidden">
<span class="fa fa-times" style="cursor:pointer" @click.stop="hidden.splice(i, 1)"></span>
{{user}}
</div>
</template>
<template v-else>{{l('settings.hideAds.empty')}}</template>
</div>
<div v-show="selectedTab === '4'" style="display:flex;padding-top:10px">
2018-04-16 23:14:13 +00:00
<select id="import" class="form-control" v-model="importCharacter" style="flex:1;margin-right:10px">
2017-09-02 01:50:31 +00:00
<option value="">{{l('settings.import.selectCharacter')}}</option>
<option v-for="character in availableImports" :value="character">{{character}}</option>
</select>
<button class="btn btn-secondary" @click="doImport" :disabled="!importCharacter">{{l('settings.import')}}</button>
2017-09-02 01:50:31 +00:00
</div>
</modal>
</template>
<script lang="ts">
2019-01-03 17:38:17 +00:00
import {Component} from '@f-list/vue-ts';
2017-09-02 01:50:31 +00:00
import CustomDialog from '../components/custom_dialog';
import Modal from '../components/Modal.vue';
import Tabs from '../components/tabs';
2017-09-02 01:50:31 +00:00
import core from './core';
import {Settings as SettingsInterface} from './interfaces';
import l from './localize';
@Component({
components: {modal: Modal, tabs: Tabs}
})
2017-09-02 01:50:31 +00:00
export default class SettingsView extends CustomDialog {
l = l;
availableImports: ReadonlyArray<string> = [];
2018-04-16 23:14:13 +00:00
selectedTab = '0';
2017-09-02 01:50:31 +00:00
importCharacter = '';
playSound!: boolean;
clickOpensMessage!: boolean;
disallowedTags!: string;
notifications!: boolean;
highlight!: boolean;
highlightWords!: string;
showAvatars!: boolean;
animatedEicons!: boolean;
idleTimer!: string;
messageSeparators!: boolean;
eventMessages!: boolean;
joinMessages!: boolean;
alwaysNotify!: boolean;
logMessages!: boolean;
logAds!: boolean;
2018-08-10 16:59:37 +00:00
fontSize!: string;
showNeedsReply!: boolean;
2018-03-28 13:51:05 +00:00
enterSend!: boolean;
colorBookmarks!: boolean;
2018-07-20 01:12:26 +00:00
bbCodeBar!: boolean;
2017-09-02 01:50:31 +00:00
risingAdScore!: boolean;
risingLinkPreview!: boolean;
risingAutoCompareKinks!: boolean;
2020-10-25 16:55:21 +00:00
risingAutoExpandCustomKinks!: boolean;
risingCharacterPreview!: boolean;
risingComparisonInUserMenu!: boolean;
risingComparisonInSearch!: boolean;
2020-11-27 20:58:14 +00:00
risingShowUnreadOfflineCount!: boolean;
2020-10-25 16:55:21 +00:00
2019-01-03 17:38:17 +00:00
async load(): Promise<void> {
2017-09-02 01:50:31 +00:00
const settings = core.state.settings;
this.playSound = settings.playSound;
this.clickOpensMessage = settings.clickOpensMessage;
this.disallowedTags = settings.disallowedTags.join(',');
this.notifications = settings.notifications;
this.highlight = settings.highlight;
this.highlightWords = settings.highlightWords.join(',');
this.showAvatars = settings.showAvatars;
this.animatedEicons = settings.animatedEicons;
this.idleTimer = settings.idleTimer.toString();
this.messageSeparators = settings.messageSeparators;
this.eventMessages = settings.eventMessages;
this.joinMessages = settings.joinMessages;
this.alwaysNotify = settings.alwaysNotify;
this.logMessages = settings.logMessages;
this.logAds = settings.logAds;
2018-08-10 16:59:37 +00:00
this.fontSize = settings.fontSize.toString();
this.showNeedsReply = settings.showNeedsReply;
2018-03-28 13:51:05 +00:00
this.enterSend = settings.enterSend;
this.colorBookmarks = settings.colorBookmarks;
2018-07-20 01:12:26 +00:00
this.bbCodeBar = settings.bbCodeBar;
2019-01-03 17:38:17 +00:00
this.availableImports = (await core.settingsStore.getAvailableCharacters()).filter((x) => x !== core.connection.character);
this.risingAdScore = settings.risingAdScore;
this.risingLinkPreview = settings.risingLinkPreview;
this.risingAutoCompareKinks = settings.risingAutoCompareKinks;
2020-10-25 16:55:21 +00:00
this.risingAutoExpandCustomKinks = settings.risingAutoExpandCustomKinks;
this.risingCharacterPreview = settings.risingCharacterPreview;
this.risingComparisonInUserMenu = settings.risingComparisonInUserMenu;
this.risingComparisonInSearch = settings.risingComparisonInSearch;
2020-11-27 20:58:14 +00:00
this.risingShowUnreadOfflineCount = settings.risingShowUnreadOfflineCount;
2019-01-03 17:38:17 +00:00
}
2017-09-02 01:50:31 +00:00
async doImport(): Promise<void> {
if(!confirm(l('settings.import.confirm', this.importCharacter, core.connection.character))) return;
const importKey = async(key: keyof SettingsInterface.Keys) => {
const settings = await core.settingsStore.get(key, this.importCharacter);
if(settings !== undefined) await core.settingsStore.set(key, settings);
};
await importKey('settings');
await importKey('pinned');
await importKey('modes');
2017-09-02 01:50:31 +00:00
await importKey('conversationSettings');
2019-01-03 17:38:17 +00:00
core.connection.close(false);
}
get hidden(): string[] {
return core.state.hiddenUsers;
2017-09-02 01:50:31 +00:00
}
async submit(): Promise<void> {
2018-08-10 16:59:37 +00:00
const idleTimer = parseInt(this.idleTimer, 10);
2018-09-28 00:08:10 +00:00
const fontSize = parseFloat(this.fontSize);
2017-09-02 01:50:31 +00:00
core.state.settings = {
playSound: this.playSound,
clickOpensMessage: this.clickOpensMessage,
disallowedTags: this.disallowedTags.split(',').map((x) => x.trim()).filter((x) => x.length),
notifications: this.notifications,
highlight: this.highlight,
highlightWords: this.highlightWords.split(',').map((x) => x.trim()).filter((x) => x.length),
showAvatars: this.showAvatars,
animatedEicons: this.animatedEicons,
2018-08-10 16:59:37 +00:00
idleTimer: isNaN(idleTimer) ? 0 : idleTimer < 0 ? 0 : idleTimer > 1440 ? 1440 : idleTimer,
2017-09-02 01:50:31 +00:00
messageSeparators: this.messageSeparators,
eventMessages: this.eventMessages,
joinMessages: this.joinMessages,
alwaysNotify: this.alwaysNotify,
logMessages: this.logMessages,
logAds: this.logAds,
2018-08-10 16:59:37 +00:00
fontSize: isNaN(fontSize) ? 14 : fontSize < 10 ? 10 : fontSize > 24 ? 24 : fontSize,
2018-03-28 13:51:05 +00:00
showNeedsReply: this.showNeedsReply,
enterSend: this.enterSend,
2018-07-20 01:12:26 +00:00
colorBookmarks: this.colorBookmarks,
bbCodeBar: this.bbCodeBar,
risingAdScore: this.risingAdScore,
risingLinkPreview: this.risingLinkPreview,
2020-10-25 16:55:21 +00:00
risingAutoCompareKinks: this.risingAutoCompareKinks,
risingAutoExpandCustomKinks: this.risingAutoExpandCustomKinks,
risingCharacterPreview: this.risingCharacterPreview,
risingComparisonInUserMenu: this.risingComparisonInUserMenu,
2020-11-27 20:58:14 +00:00
risingComparisonInSearch: this.risingComparisonInSearch,
risingShowUnreadOfflineCount: this.risingShowUnreadOfflineCount
2017-09-02 01:50:31 +00:00
};
2018-01-06 16:14:21 +00:00
if(this.notifications) await core.notifications.requestPermission();
2017-09-02 01:50:31 +00:00
}
}
</script>
<style>
#settings .form-group {
margin-left: 0;
margin-right: 0;
}
2020-10-25 16:55:21 +00:00
</style>