2022-03-17 18:28:19 +11:00
|
|
|
import { createApp, configureCompat } from 'vue'
|
2021-04-25 00:56:00 +10:00
|
|
|
import { createRouter, createWebHistory } from 'vue-router'
|
2022-03-17 18:28:19 +11:00
|
|
|
import vClickOutside from 'click-outside-vue3'
|
2021-04-25 00:56:00 +10:00
|
|
|
|
|
|
|
import { FontAwesomeIcon, FontAwesomeLayers } from '@fortawesome/vue-fontawesome'
|
|
|
|
|
2018-10-27 00:16:23 +11:00
|
|
|
import App from '../App.vue'
|
2021-04-25 00:56:00 +10:00
|
|
|
import routes from './routes'
|
|
|
|
import VBodyScrollLock from 'src/directives/body_scroll_lock'
|
|
|
|
|
2019-04-02 06:41:34 +11:00
|
|
|
import { windowWidth } from '../services/window_utils/window_utils'
|
2019-05-23 02:13:41 +10:00
|
|
|
import { getOrCreateApp, getClientToken } from '../services/new_api/oauth.js'
|
|
|
|
import backendInteractorService from '../services/backend_interactor_service/backend_interactor_service.js'
|
2020-01-22 09:37:19 +11:00
|
|
|
import { CURRENT_VERSION } from '../services/theme_data/theme_data.service.js'
|
|
|
|
import { applyTheme } from '../services/style_setter/style_setter.js'
|
2020-11-03 00:46:49 +11:00
|
|
|
import FaviconService from '../services/favicon_service/favicon_service.js'
|
2018-10-27 00:16:23 +11:00
|
|
|
|
2022-03-17 18:28:19 +11:00
|
|
|
// disable compat for certain features
|
|
|
|
configureCompat({
|
2022-03-18 22:32:36 +11:00
|
|
|
COMPONENT_V_MODEL: false,
|
|
|
|
INSTANCE_SET: false,
|
|
|
|
RENDER_FUNCTION: false
|
2022-03-17 18:28:19 +11:00
|
|
|
})
|
|
|
|
|
2020-06-26 21:47:02 +10:00
|
|
|
let staticInitialResults = null
|
|
|
|
|
|
|
|
const parsedInitialResults = () => {
|
|
|
|
if (!document.getElementById('initial-results')) {
|
|
|
|
return null
|
|
|
|
}
|
|
|
|
if (!staticInitialResults) {
|
|
|
|
staticInitialResults = JSON.parse(document.getElementById('initial-results').textContent)
|
|
|
|
}
|
|
|
|
return staticInitialResults
|
|
|
|
}
|
|
|
|
|
2020-07-09 19:20:07 +10:00
|
|
|
const decodeUTF8Base64 = (data) => {
|
|
|
|
const rawData = atob(data)
|
|
|
|
const array = Uint8Array.from([...rawData].map((char) => char.charCodeAt(0)))
|
|
|
|
const text = new TextDecoder().decode(array)
|
|
|
|
return text
|
|
|
|
}
|
|
|
|
|
2020-06-26 21:47:02 +10:00
|
|
|
const preloadFetch = async (request) => {
|
|
|
|
const data = parsedInitialResults()
|
|
|
|
if (!data || !data[request]) {
|
|
|
|
return window.fetch(request)
|
|
|
|
}
|
2020-07-09 19:20:07 +10:00
|
|
|
const decoded = decodeUTF8Base64(data[request])
|
|
|
|
const requestData = JSON.parse(decoded)
|
2020-06-26 21:47:02 +10:00
|
|
|
return {
|
|
|
|
ok: true,
|
2020-07-07 21:47:01 +10:00
|
|
|
json: () => requestData,
|
|
|
|
text: () => requestData
|
2020-06-26 21:47:02 +10:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-06-25 01:54:35 +10:00
|
|
|
const getInstanceConfig = async ({ store }) => {
|
2019-03-13 21:57:30 +11:00
|
|
|
try {
|
2020-06-27 19:26:19 +10:00
|
|
|
const res = await preloadFetch('/api/v1/instance')
|
2019-03-13 22:41:39 +11:00
|
|
|
if (res.ok) {
|
|
|
|
const data = await res.json()
|
2020-06-25 01:54:35 +10:00
|
|
|
const textlimit = data.max_toot_chars
|
|
|
|
const vapidPublicKey = data.pleroma.vapid_public_key
|
2018-10-27 00:16:23 +11:00
|
|
|
|
2020-06-25 01:54:35 +10:00
|
|
|
store.dispatch('setInstanceOption', { name: 'textlimit', value: textlimit })
|
2021-02-15 20:10:09 +11:00
|
|
|
store.dispatch('setInstanceOption', { name: 'accountApprovalRequired', value: data.approval_required })
|
2018-12-19 05:26:14 +11:00
|
|
|
|
2018-12-11 02:36:25 +11:00
|
|
|
if (vapidPublicKey) {
|
|
|
|
store.dispatch('setInstanceOption', { name: 'vapidPublicKey', value: vapidPublicKey })
|
|
|
|
}
|
2019-03-13 22:41:39 +11:00
|
|
|
} else {
|
|
|
|
throw (res)
|
|
|
|
}
|
2019-03-13 21:57:30 +11:00
|
|
|
} catch (error) {
|
2020-06-25 01:54:35 +10:00
|
|
|
console.error('Could not load instance config, potentially fatal')
|
2019-03-13 21:57:30 +11:00
|
|
|
console.error(error)
|
|
|
|
}
|
|
|
|
}
|
2018-10-27 00:16:23 +11:00
|
|
|
|
2020-03-26 04:06:48 +11:00
|
|
|
const getBackendProvidedConfig = async ({ store }) => {
|
|
|
|
try {
|
|
|
|
const res = await window.fetch('/api/pleroma/frontend_configurations')
|
|
|
|
if (res.ok) {
|
|
|
|
const data = await res.json()
|
|
|
|
return data.pleroma_fe
|
2019-03-13 22:41:39 +11:00
|
|
|
} else {
|
|
|
|
throw (res)
|
|
|
|
}
|
2019-03-13 21:57:30 +11:00
|
|
|
} catch (error) {
|
2020-03-26 04:06:48 +11:00
|
|
|
console.error('Could not load backend-provided frontend config, potentially fatal')
|
2019-03-13 21:57:30 +11:00
|
|
|
console.error(error)
|
|
|
|
}
|
|
|
|
}
|
2018-10-27 00:16:23 +11:00
|
|
|
|
2019-03-13 21:57:30 +11:00
|
|
|
const getStaticConfig = async () => {
|
|
|
|
try {
|
|
|
|
const res = await window.fetch('/static/config.json')
|
2019-03-13 22:41:39 +11:00
|
|
|
if (res.ok) {
|
|
|
|
return res.json()
|
|
|
|
} else {
|
|
|
|
throw (res)
|
|
|
|
}
|
2019-03-13 21:57:30 +11:00
|
|
|
} catch (error) {
|
|
|
|
console.warn('Failed to load static/config.json, continuing without it.')
|
|
|
|
console.warn(error)
|
|
|
|
return {}
|
|
|
|
}
|
|
|
|
}
|
2019-01-25 05:03:13 +11:00
|
|
|
|
2019-03-13 21:57:30 +11:00
|
|
|
const setSettings = async ({ apiConfig, staticConfig, store }) => {
|
|
|
|
const overrides = window.___pleromafe_dev_overrides || {}
|
|
|
|
const env = window.___pleromafe_mode.NODE_ENV
|
|
|
|
|
|
|
|
// This takes static config and overrides properties that are present in apiConfig
|
|
|
|
let config = {}
|
|
|
|
if (overrides.staticConfigPreference && env === 'development') {
|
|
|
|
console.warn('OVERRIDING API CONFIG WITH STATIC CONFIG')
|
|
|
|
config = Object.assign({}, apiConfig, staticConfig)
|
|
|
|
} else {
|
|
|
|
config = Object.assign({}, staticConfig, apiConfig)
|
|
|
|
}
|
|
|
|
|
|
|
|
const copyInstanceOption = (name) => {
|
|
|
|
store.dispatch('setInstanceOption', { name, value: config[name] })
|
|
|
|
}
|
|
|
|
|
|
|
|
copyInstanceOption('nsfwCensorImage')
|
|
|
|
copyInstanceOption('background')
|
|
|
|
copyInstanceOption('hidePostStats')
|
2022-03-01 08:35:00 +11:00
|
|
|
copyInstanceOption('hideBotIndication')
|
2019-03-13 21:57:30 +11:00
|
|
|
copyInstanceOption('hideUserStats')
|
|
|
|
copyInstanceOption('hideFilteredStatuses')
|
|
|
|
copyInstanceOption('logo')
|
2018-10-27 00:16:23 +11:00
|
|
|
|
2019-03-13 21:57:30 +11:00
|
|
|
store.dispatch('setInstanceOption', {
|
|
|
|
name: 'logoMask',
|
|
|
|
value: typeof config.logoMask === 'undefined'
|
|
|
|
? true
|
|
|
|
: config.logoMask
|
|
|
|
})
|
|
|
|
|
|
|
|
store.dispatch('setInstanceOption', {
|
|
|
|
name: 'logoMargin',
|
|
|
|
value: typeof config.logoMargin === 'undefined'
|
|
|
|
? 0
|
|
|
|
: config.logoMargin
|
|
|
|
})
|
2020-10-30 06:13:31 +11:00
|
|
|
copyInstanceOption('logoLeft')
|
2019-06-13 06:16:55 +10:00
|
|
|
store.commit('authFlow/setInitialStrategy', config.loginMethod)
|
2019-03-13 21:57:30 +11:00
|
|
|
|
|
|
|
copyInstanceOption('redirectRootNoLogin')
|
|
|
|
copyInstanceOption('redirectRootLogin')
|
|
|
|
copyInstanceOption('showInstanceSpecificPanel')
|
2019-03-30 21:31:50 +11:00
|
|
|
copyInstanceOption('minimalScopesMode')
|
2019-03-03 00:07:14 +11:00
|
|
|
copyInstanceOption('hideMutedPosts')
|
2019-03-13 21:57:30 +11:00
|
|
|
copyInstanceOption('collapseMessageWithSubject')
|
|
|
|
copyInstanceOption('scopeCopy')
|
|
|
|
copyInstanceOption('subjectLineBehavior')
|
|
|
|
copyInstanceOption('postContentType')
|
|
|
|
copyInstanceOption('alwaysShowSubjectInput')
|
|
|
|
copyInstanceOption('showFeaturesPanel')
|
2019-12-02 11:34:01 +11:00
|
|
|
copyInstanceOption('hideSitename')
|
2020-05-29 03:28:32 +10:00
|
|
|
copyInstanceOption('sidebarRight')
|
2019-03-13 21:57:30 +11:00
|
|
|
|
|
|
|
return store.dispatch('setTheme', config['theme'])
|
|
|
|
}
|
2018-10-27 00:16:23 +11:00
|
|
|
|
2019-03-13 22:10:57 +11:00
|
|
|
const getTOS = async ({ store }) => {
|
|
|
|
try {
|
|
|
|
const res = await window.fetch('/static/terms-of-service.html')
|
|
|
|
if (res.ok) {
|
|
|
|
const html = await res.text()
|
2018-10-27 00:16:23 +11:00
|
|
|
store.dispatch('setInstanceOption', { name: 'tos', value: html })
|
2019-03-13 22:10:57 +11:00
|
|
|
} else {
|
|
|
|
throw (res)
|
|
|
|
}
|
|
|
|
} catch (e) {
|
|
|
|
console.warn("Can't load TOS")
|
|
|
|
console.warn(e)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const getInstancePanel = async ({ store }) => {
|
|
|
|
try {
|
2020-06-26 21:47:02 +10:00
|
|
|
const res = await preloadFetch('/instance/panel.html')
|
2019-03-13 22:10:57 +11:00
|
|
|
if (res.ok) {
|
|
|
|
const html = await res.text()
|
|
|
|
store.dispatch('setInstanceOption', { name: 'instanceSpecificPanelContent', value: html })
|
|
|
|
} else {
|
|
|
|
throw (res)
|
|
|
|
}
|
|
|
|
} catch (e) {
|
|
|
|
console.warn("Can't load instance panel")
|
2019-03-13 22:26:40 +11:00
|
|
|
console.warn(e)
|
|
|
|
}
|
|
|
|
}
|
2018-10-27 00:16:23 +11:00
|
|
|
|
2019-07-25 05:35:52 +10:00
|
|
|
const getStickers = async ({ store }) => {
|
|
|
|
try {
|
|
|
|
const res = await window.fetch('/static/stickers.json')
|
|
|
|
if (res.ok) {
|
|
|
|
const values = await res.json()
|
|
|
|
const stickers = (await Promise.all(
|
|
|
|
Object.entries(values).map(async ([name, path]) => {
|
|
|
|
const resPack = await window.fetch(path + 'pack.json')
|
|
|
|
var meta = {}
|
|
|
|
if (resPack.ok) {
|
|
|
|
meta = await resPack.json()
|
|
|
|
}
|
|
|
|
return {
|
|
|
|
pack: name,
|
|
|
|
path,
|
|
|
|
meta
|
|
|
|
}
|
|
|
|
})
|
|
|
|
)).sort((a, b) => {
|
|
|
|
return a.meta.title.localeCompare(b.meta.title)
|
|
|
|
})
|
|
|
|
store.dispatch('setInstanceOption', { name: 'stickers', value: stickers })
|
|
|
|
} else {
|
|
|
|
throw (res)
|
|
|
|
}
|
|
|
|
} catch (e) {
|
|
|
|
console.warn("Can't load stickers")
|
|
|
|
console.warn(e)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-05-23 02:13:41 +10:00
|
|
|
const getAppSecret = async ({ store }) => {
|
|
|
|
const { state, commit } = store
|
|
|
|
const { oauth, instance } = state
|
|
|
|
return getOrCreateApp({ ...oauth, instance: instance.server, commit })
|
|
|
|
.then((app) => getClientToken({ ...app, instance: instance.server }))
|
|
|
|
.then((token) => {
|
2019-06-13 17:11:17 +10:00
|
|
|
commit('setAppToken', token.access_token)
|
2019-05-23 02:13:41 +10:00
|
|
|
commit('setBackendInteractor', backendInteractorService(store.getters.getToken()))
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2019-12-16 06:29:45 +11:00
|
|
|
const resolveStaffAccounts = ({ store, accounts }) => {
|
|
|
|
const nicknames = accounts.map(uri => uri.split('/').pop())
|
2019-11-09 16:21:07 +11:00
|
|
|
store.dispatch('setInstanceOption', { name: 'staffAccounts', value: nicknames })
|
|
|
|
}
|
|
|
|
|
2019-03-13 22:26:40 +11:00
|
|
|
const getNodeInfo = async ({ store }) => {
|
|
|
|
try {
|
2020-06-26 21:47:02 +10:00
|
|
|
const res = await preloadFetch('/nodeinfo/2.0.json')
|
2019-03-13 22:26:40 +11:00
|
|
|
if (res.ok) {
|
|
|
|
const data = await res.json()
|
2018-10-27 00:16:23 +11:00
|
|
|
const metadata = data.metadata
|
2018-10-27 01:13:05 +11:00
|
|
|
const features = metadata.features
|
2020-03-26 04:06:48 +11:00
|
|
|
store.dispatch('setInstanceOption', { name: 'name', value: metadata.nodeName })
|
|
|
|
store.dispatch('setInstanceOption', { name: 'registrationOpen', value: data.openRegistrations })
|
2018-10-27 01:13:05 +11:00
|
|
|
store.dispatch('setInstanceOption', { name: 'mediaProxyAvailable', value: features.includes('media_proxy') })
|
2020-03-26 04:06:48 +11:00
|
|
|
store.dispatch('setInstanceOption', { name: 'safeDM', value: features.includes('safe_dm_mentions') })
|
2021-06-02 07:48:40 +10:00
|
|
|
store.dispatch('setInstanceOption', { name: 'shoutAvailable', value: features.includes('chat') })
|
2020-05-07 23:10:53 +10:00
|
|
|
store.dispatch('setInstanceOption', { name: 'pleromaChatMessagesAvailable', value: features.includes('pleroma_chat_messages') })
|
2018-10-27 01:13:05 +11:00
|
|
|
store.dispatch('setInstanceOption', { name: 'gopherAvailable', value: features.includes('gopher') })
|
2019-06-19 06:28:31 +10:00
|
|
|
store.dispatch('setInstanceOption', { name: 'pollsAvailable', value: features.includes('polls') })
|
|
|
|
store.dispatch('setInstanceOption', { name: 'pollLimits', value: metadata.pollLimits })
|
2019-09-05 21:23:28 +10:00
|
|
|
store.dispatch('setInstanceOption', { name: 'mailerEnabled', value: metadata.mailerEnabled })
|
2018-10-27 00:16:23 +11:00
|
|
|
|
2020-03-26 04:06:48 +11:00
|
|
|
const uploadLimits = metadata.uploadLimits
|
|
|
|
store.dispatch('setInstanceOption', { name: 'uploadlimit', value: parseInt(uploadLimits.general) })
|
|
|
|
store.dispatch('setInstanceOption', { name: 'avatarlimit', value: parseInt(uploadLimits.avatar) })
|
|
|
|
store.dispatch('setInstanceOption', { name: 'backgroundlimit', value: parseInt(uploadLimits.background) })
|
|
|
|
store.dispatch('setInstanceOption', { name: 'bannerlimit', value: parseInt(uploadLimits.banner) })
|
2020-06-10 04:24:55 +10:00
|
|
|
store.dispatch('setInstanceOption', { name: 'fieldsLimits', value: metadata.fieldsLimits })
|
2020-03-26 04:06:48 +11:00
|
|
|
|
2018-12-27 00:50:48 +11:00
|
|
|
store.dispatch('setInstanceOption', { name: 'restrictedNicknames', value: metadata.restrictedNicknames })
|
2019-03-15 08:35:45 +11:00
|
|
|
store.dispatch('setInstanceOption', { name: 'postFormats', value: metadata.postFormats })
|
2018-12-27 00:50:48 +11:00
|
|
|
|
2018-10-27 00:16:23 +11:00
|
|
|
const suggestions = metadata.suggestions
|
|
|
|
store.dispatch('setInstanceOption', { name: 'suggestionsEnabled', value: suggestions.enabled })
|
|
|
|
store.dispatch('setInstanceOption', { name: 'suggestionsWeb', value: suggestions.web })
|
2019-03-11 10:58:12 +11:00
|
|
|
|
|
|
|
const software = data.software
|
|
|
|
store.dispatch('setInstanceOption', { name: 'backendVersion', value: software.version })
|
2019-10-02 03:14:14 +10:00
|
|
|
store.dispatch('setInstanceOption', { name: 'pleromaBackend', value: software.name === 'pleroma' })
|
2019-03-11 10:58:12 +11:00
|
|
|
|
2019-11-10 12:53:03 +11:00
|
|
|
const priv = metadata.private
|
|
|
|
store.dispatch('setInstanceOption', { name: 'private', value: priv })
|
|
|
|
|
2019-03-11 10:58:12 +11:00
|
|
|
const frontendVersion = window.___pleromafe_commit_hash
|
|
|
|
store.dispatch('setInstanceOption', { name: 'frontendVersion', value: frontendVersion })
|
2019-11-09 16:21:07 +11:00
|
|
|
|
2019-11-09 17:09:32 +11:00
|
|
|
const federation = metadata.federation
|
2020-02-14 06:35:46 +11:00
|
|
|
|
|
|
|
store.dispatch('setInstanceOption', {
|
|
|
|
name: 'tagPolicyAvailable',
|
|
|
|
value: typeof federation.mrf_policies === 'undefined'
|
|
|
|
? false
|
|
|
|
: metadata.federation.mrf_policies.includes('TagPolicy')
|
|
|
|
})
|
|
|
|
|
2019-11-09 17:09:32 +11:00
|
|
|
store.dispatch('setInstanceOption', { name: 'federationPolicy', value: federation })
|
2019-12-13 08:29:50 +11:00
|
|
|
store.dispatch('setInstanceOption', {
|
|
|
|
name: 'federating',
|
|
|
|
value: typeof federation.enabled === 'undefined'
|
|
|
|
? true
|
|
|
|
: federation.enabled
|
|
|
|
})
|
2019-11-09 17:09:32 +11:00
|
|
|
|
2020-02-25 04:19:00 +11:00
|
|
|
const accountActivationRequired = metadata.accountActivationRequired
|
|
|
|
store.dispatch('setInstanceOption', { name: 'accountActivationRequired', value: accountActivationRequired })
|
|
|
|
|
2019-11-09 16:21:07 +11:00
|
|
|
const accounts = metadata.staffAccounts
|
2019-12-16 06:29:45 +11:00
|
|
|
resolveStaffAccounts({ store, accounts })
|
2019-03-13 22:26:40 +11:00
|
|
|
} else {
|
|
|
|
throw (res)
|
|
|
|
}
|
|
|
|
} catch (e) {
|
|
|
|
console.warn('Could not load nodeinfo')
|
|
|
|
console.warn(e)
|
2019-03-13 22:10:57 +11:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-04-02 04:46:30 +11:00
|
|
|
const setConfig = async ({ store }) => {
|
|
|
|
// apiConfig, staticConfig
|
2020-03-26 04:06:48 +11:00
|
|
|
const configInfos = await Promise.all([getBackendProvidedConfig({ store }), getStaticConfig()])
|
2019-04-02 04:46:30 +11:00
|
|
|
const apiConfig = configInfos[0]
|
|
|
|
const staticConfig = configInfos[1]
|
|
|
|
|
2019-05-23 02:13:41 +10:00
|
|
|
await setSettings({ store, apiConfig, staticConfig }).then(getAppSecret({ store }))
|
2019-04-02 04:46:30 +11:00
|
|
|
}
|
|
|
|
|
2019-04-02 06:32:13 +11:00
|
|
|
const checkOAuthToken = async ({ store }) => {
|
|
|
|
return new Promise(async (resolve, reject) => {
|
2019-06-13 17:05:22 +10:00
|
|
|
if (store.getters.getUserToken()) {
|
2019-04-02 06:32:13 +11:00
|
|
|
try {
|
2019-06-13 17:00:06 +10:00
|
|
|
await store.dispatch('loginUser', store.getters.getUserToken())
|
2019-04-02 06:32:13 +11:00
|
|
|
} catch (e) {
|
2020-01-22 09:37:19 +11:00
|
|
|
console.error(e)
|
2019-04-02 06:32:13 +11:00
|
|
|
}
|
|
|
|
}
|
|
|
|
resolve()
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2019-03-13 21:57:30 +11:00
|
|
|
const afterStoreSetup = async ({ store, i18n }) => {
|
2019-04-02 06:41:34 +11:00
|
|
|
const width = windowWidth()
|
2019-03-24 07:21:57 +11:00
|
|
|
store.dispatch('setMobileLayout', width <= 800)
|
2020-03-26 04:06:48 +11:00
|
|
|
|
2020-11-03 00:46:49 +11:00
|
|
|
FaviconService.initFaviconService()
|
|
|
|
|
2020-03-26 04:06:48 +11:00
|
|
|
const overrides = window.___pleromafe_dev_overrides || {}
|
|
|
|
const server = (typeof overrides.target !== 'undefined') ? overrides.target : window.location.origin
|
|
|
|
store.dispatch('setInstanceOption', { name: 'server', value: server })
|
|
|
|
|
2020-01-22 09:37:19 +11:00
|
|
|
await setConfig({ store })
|
|
|
|
|
|
|
|
const { customTheme, customThemeSource } = store.state.config
|
|
|
|
const { theme } = store.state.instance
|
|
|
|
const customThemePresent = customThemeSource || customTheme
|
|
|
|
|
|
|
|
if (customThemePresent) {
|
2020-01-23 08:26:24 +11:00
|
|
|
if (customThemeSource && customThemeSource.themeEngineVersion === CURRENT_VERSION) {
|
2020-01-22 09:37:19 +11:00
|
|
|
applyTheme(customThemeSource)
|
|
|
|
} else {
|
|
|
|
applyTheme(customTheme)
|
|
|
|
}
|
|
|
|
} else if (theme) {
|
|
|
|
// do nothing, it will load asynchronously
|
|
|
|
} else {
|
|
|
|
console.error('Failed to load any theme!')
|
|
|
|
}
|
2019-03-24 07:21:57 +11:00
|
|
|
|
2019-04-02 04:46:30 +11:00
|
|
|
// Now we can try getting the server settings and logging in
|
2020-06-27 19:32:01 +10:00
|
|
|
// Most of these are preloaded into the index.html so blocking is minimized
|
2019-04-02 06:32:13 +11:00
|
|
|
await Promise.all([
|
|
|
|
checkOAuthToken({ store }),
|
|
|
|
getInstancePanel({ store }),
|
2020-03-26 04:06:48 +11:00
|
|
|
getNodeInfo({ store }),
|
2020-06-25 01:54:35 +10:00
|
|
|
getInstanceConfig({ store })
|
2019-04-02 06:32:13 +11:00
|
|
|
])
|
2019-03-13 21:57:30 +11:00
|
|
|
|
2020-04-22 06:27:51 +10:00
|
|
|
// Start fetching things that don't need to block the UI
|
|
|
|
store.dispatch('fetchMutes')
|
2020-06-27 19:32:01 +10:00
|
|
|
getTOS({ store })
|
|
|
|
getStickers({ store })
|
2020-04-22 06:27:51 +10:00
|
|
|
|
2021-04-25 00:56:00 +10:00
|
|
|
const router = createRouter({
|
|
|
|
history: createWebHistory(),
|
2019-03-13 21:57:30 +11:00
|
|
|
routes: routes(store),
|
|
|
|
scrollBehavior: (to, _from, savedPosition) => {
|
|
|
|
if (to.matched.some(m => m.meta.dontScroll)) {
|
|
|
|
return false
|
|
|
|
}
|
2021-04-25 00:56:00 +10:00
|
|
|
return savedPosition || { left: 0, top: 0 }
|
2019-03-13 21:57:30 +11:00
|
|
|
}
|
|
|
|
})
|
|
|
|
|
2021-04-25 00:56:00 +10:00
|
|
|
const app = createApp(App)
|
|
|
|
|
|
|
|
app.use(router)
|
|
|
|
app.use(store)
|
|
|
|
app.use(i18n)
|
|
|
|
|
2022-03-17 18:28:19 +11:00
|
|
|
app.use(vClickOutside)
|
2021-04-25 00:56:00 +10:00
|
|
|
app.use(VBodyScrollLock)
|
|
|
|
|
|
|
|
app.component('FAIcon', FontAwesomeIcon)
|
|
|
|
app.component('FALayers', FontAwesomeLayers)
|
|
|
|
|
|
|
|
app.mount('#app')
|
|
|
|
|
|
|
|
return app
|
2018-10-27 00:16:23 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
export default afterStoreSetup
|