akkoma-fe/src/modules/instance.js

189 lines
5.4 KiB
JavaScript
Raw Normal View History

2018-09-09 18:21:23 +00:00
import { set } from 'vue'
import { getPreset, applyTheme } from '../services/style_setter/style_setter.js'
import { CURRENT_VERSION } from '../services/theme_data/theme_data.service.js'
import { instanceDefaultProperties } from './config.js'
2018-09-09 18:21:23 +00:00
const defaultState = {
2020-05-13 19:43:36 +00:00
// not user configurable
name: 'Pleroma FE',
// Stuff from static/config.json and apiConfig
alwaysShowSubjectInput: true,
2020-05-13 19:40:46 +00:00
background: '/static/aurora_borealis.jpg',
2018-09-09 18:21:23 +00:00
collapseMessageWithSubject: false,
2020-05-13 19:40:46 +00:00
disableChat: false,
greentext: false,
hideFilteredStatuses: false,
hideMutedPosts: false,
hidePostStats: false,
2020-05-13 19:40:46 +00:00
hideSitename: false,
hideUserStats: false,
2020-05-13 19:46:31 +00:00
loginMethod: 'password',
2020-05-13 19:40:46 +00:00
logo: '/static/logo.png',
logoMargin: '.2em',
logoMask: true,
minimalScopesMode: false,
nsfwCensorImage: undefined,
postContentType: 'text/plain',
redirectRootLogin: '/main/friends',
redirectRootNoLogin: '/main/all',
registrationOpen: true,
safeDM: true,
2018-09-25 12:16:26 +00:00
scopeCopy: true,
2020-05-13 19:40:46 +00:00
server: 'http://localhost:4040/',
showFeaturesPanel: true,
showInstanceSpecificPanel: false,
2018-09-25 11:47:02 +00:00
subjectLineBehavior: 'email',
2020-05-13 19:40:46 +00:00
textlimit: 5000,
theme: 'pleroma-dark',
themeData: undefined,
2018-12-13 17:41:01 +00:00
vapidPublicKey: undefined,
2018-09-09 18:21:23 +00:00
// Nasty stuff
pleromaBackend: true,
emoji: [],
emojiFetched: false,
2018-09-09 18:21:23 +00:00
customEmoji: [],
customEmojiFetched: false,
restrictedNicknames: [],
postFormats: [],
// Feature-set, apparently, not everything here is reported...
mediaProxyAvailable: false,
chatAvailable: false,
gopherAvailable: false,
suggestionsEnabled: false,
suggestionsWeb: '',
2018-09-09 18:21:23 +00:00
// Html stuff
instanceSpecificPanelContent: '',
tos: '',
// Version Information
backendVersion: '',
2019-06-18 20:28:31 +00:00
frontendVersion: '',
pollsAvailable: false,
pollLimits: {
max_options: 4,
max_option_chars: 255,
min_expiration: 60,
max_expiration: 60 * 60 * 24
}
2018-09-09 18:21:23 +00:00
}
const instance = {
state: defaultState,
mutations: {
setInstanceOption (state, { name, value }) {
if (typeof value !== 'undefined') {
set(state, name, value)
}
2018-09-09 18:21:23 +00:00
}
},
getters: {
instanceDefaultConfig (state) {
return instanceDefaultProperties
.map(key => [key, state[key]])
.reduce((acc, [key, value]) => ({ ...acc, [key]: value }), {})
}
},
2018-09-09 18:21:23 +00:00
actions: {
setInstanceOption ({ commit, dispatch }, { name, value }) {
2019-07-05 07:02:14 +00:00
commit('setInstanceOption', { name, value })
2018-09-09 18:21:23 +00:00
switch (name) {
case 'name':
dispatch('setPageTitle')
break
case 'chatAvailable':
if (value) {
dispatch('initializeSocket')
}
break
case 'theme':
dispatch('setTheme', value)
break
2018-09-09 18:21:23 +00:00
}
},
async getStaticEmoji ({ commit }) {
try {
const res = await window.fetch('/static/emoji.json')
if (res.ok) {
const values = await res.json()
const emoji = Object.keys(values).map((key) => {
return {
displayText: key,
imageUrl: false,
replacement: values[key]
}
}).sort((a, b) => a.displayText - b.displayText)
commit('setInstanceOption', { name: 'emoji', value: emoji })
} else {
throw (res)
}
} catch (e) {
console.warn("Can't load static emoji")
console.warn(e)
}
},
async getCustomEmoji ({ commit, state }) {
try {
const res = await window.fetch('/api/pleroma/emoji.json')
if (res.ok) {
const result = await res.json()
const values = Array.isArray(result) ? Object.assign({}, ...result) : result
const emoji = Object.entries(values).map(([key, value]) => {
const imageUrl = value.image_url
return {
displayText: key,
imageUrl: imageUrl ? state.server + imageUrl : value,
tags: imageUrl ? value.tags.sort((a, b) => a > b ? 1 : 0) : ['utf'],
replacement: `:${key}: `
}
// Technically could use tags but those are kinda useless right now,
// should have been "pack" field, that would be more useful
}).sort((a, b) => a.displayText.toLowerCase() > b.displayText.toLowerCase() ? 1 : 0)
commit('setInstanceOption', { name: 'customEmoji', value: emoji })
} else {
throw (res)
}
} catch (e) {
console.warn("Can't load custom emojis")
console.warn(e)
}
},
setTheme ({ commit, rootState }, themeName) {
commit('setInstanceOption', { name: 'theme', value: themeName })
getPreset(themeName)
.then(themeData => {
commit('setInstanceOption', { name: 'themeData', value: themeData })
// No need to apply theme if there's user theme already
const { customTheme } = rootState.config
if (customTheme) return
// New theme presets don't have 'theme' property, they use 'source'
const themeSource = themeData.source
if (!themeData.theme || (themeSource && themeSource.themeEngineVersion === CURRENT_VERSION)) {
applyTheme(themeSource)
} else {
applyTheme(themeData.theme)
}
})
},
fetchEmoji ({ dispatch, state }) {
if (!state.customEmojiFetched) {
state.customEmojiFetched = true
dispatch('getCustomEmoji')
}
if (!state.emojiFetched) {
state.emojiFetched = true
dispatch('getStaticEmoji')
}
2018-09-09 18:21:23 +00:00
}
}
}
export default instance