aboutsummaryrefslogtreecommitdiff
path: root/src/main.js
diff options
context:
space:
mode:
Diffstat (limited to 'src/main.js')
-rw-r--r--src/main.js178
1 files changed, 54 insertions, 124 deletions
diff --git a/src/main.js b/src/main.js
index 3d2bcbb0..6ce2df13 100644
--- a/src/main.js
+++ b/src/main.js
@@ -1,23 +1,15 @@
import Vue from 'vue'
import VueRouter from 'vue-router'
import Vuex from 'vuex'
-import App from './App.vue'
-import PublicTimeline from './components/public_timeline/public_timeline.vue'
-import PublicAndExternalTimeline from './components/public_and_external_timeline/public_and_external_timeline.vue'
-import FriendsTimeline from './components/friends_timeline/friends_timeline.vue'
-import TagTimeline from './components/tag_timeline/tag_timeline.vue'
-import ConversationPage from './components/conversation-page/conversation-page.vue'
-import Mentions from './components/mentions/mentions.vue'
-import UserProfile from './components/user_profile/user_profile.vue'
-import Settings from './components/settings/settings.vue'
-import Registration from './components/registration/registration.vue'
-import UserSettings from './components/user_settings/user_settings.vue'
+import interfaceModule from './modules/interface.js'
+import instanceModule from './modules/instance.js'
import statusesModule from './modules/statuses.js'
import usersModule from './modules/users.js'
import apiModule from './modules/api.js'
import configModule from './modules/config.js'
import chatModule from './modules/chat.js'
+import oauthModule from './modules/oauth.js'
import VueTimeago from 'vue-timeago'
import VueI18n from 'vue-i18n'
@@ -28,6 +20,8 @@ import messages from './i18n/messages.js'
import VueChatScroll from 'vue-chat-scroll'
+import afterStoreSetup from './boot/after_store.js'
+
const currentLocale = (window.navigator.language || 'en').split('-')[0]
Vue.use(Vuex)
@@ -42,135 +36,71 @@ Vue.use(VueTimeago, {
Vue.use(VueI18n)
Vue.use(VueChatScroll)
-const persistedStateOptions = {
- paths: [
- 'config.hideAttachments',
- 'config.hideAttachmentsInConv',
- 'config.hideNsfw',
- 'config.autoLoad',
- 'config.hoverPreview',
- 'config.streaming',
- 'config.muteWords',
- 'config.customTheme',
- 'users.lastLoginName'
- ]
-}
-
-const store = new Vuex.Store({
- modules: {
- statuses: statusesModule,
- users: usersModule,
- api: apiModule,
- config: configModule,
- chat: chatModule
- },
- plugins: [createPersistedState(persistedStateOptions)],
- strict: false // Socket modifies itself, let's ignore this for now.
- // strict: process.env.NODE_ENV !== 'production'
-})
-
const i18n = new VueI18n({
+ // By default, use the browser locale, we will update it if neccessary
locale: currentLocale,
fallbackLocale: 'en',
messages
})
-window.fetch('/api/statusnet/config.json')
- .then((res) => res.json())
- .then((data) => {
- const {name, closed: registrationClosed, textlimit} = data.site
+const persistedStateOptions = {
+ paths: [
+ 'config',
+ 'users.lastLoginName',
+ 'oauth'
+ ]
+}
- store.dispatch('setOption', { name: 'name', value: name })
- store.dispatch('setOption', { name: 'registrationOpen', value: (registrationClosed === '0') })
- store.dispatch('setOption', { name: 'textlimit', value: parseInt(textlimit) })
- })
+const registerPushNotifications = store => {
+ store.subscribe((mutation, state) => {
+ const vapidPublicKey = state.instance.vapidPublicKey
+ const permission = state.interface.notificationPermission === 'granted'
+ const isUserMutation = mutation.type === 'setCurrentUser'
-window.fetch('/static/config.json')
- .then((res) => res.json())
- .then((data) => {
- const {theme, background, logo, showInstanceSpecificPanel} = data
- store.dispatch('setOption', { name: 'theme', value: theme })
- store.dispatch('setOption', { name: 'background', value: background })
- store.dispatch('setOption', { name: 'logo', value: logo })
- store.dispatch('setOption', { name: 'showInstanceSpecificPanel', value: showInstanceSpecificPanel })
- if (data['chatDisabled']) {
- store.dispatch('disableChat')
+ if (isUserMutation && vapidPublicKey && permission) {
+ return store.dispatch('registerPushNotifications')
}
if (data['nsfwCensorImage']) {
store.dispatch('setOption', { name: 'nsfwCensorImage', value: data['nsfwCensorImage'] })
}
- const routes = [
- { name: 'root', path: '/', redirect: data['defaultPath'] || '/main/all' },
- { path: '/main/all', component: PublicAndExternalTimeline },
- { path: '/main/public', component: PublicTimeline },
- { path: '/main/friends', component: FriendsTimeline },
- { path: '/tag/:tag', component: TagTimeline },
- { name: 'conversation', path: '/notice/:id', component: ConversationPage, meta: { dontScroll: true } },
- { name: 'user-profile', path: '/users/:id', component: UserProfile },
- { name: 'mentions', path: '/:username/mentions', component: Mentions },
- { name: 'settings', path: '/settings', component: Settings },
- { name: 'registration', path: '/registration', component: Registration },
- { name: 'user-settings', path: '/user-settings', component: UserSettings }
- ]
-
- const router = new VueRouter({
- mode: 'history',
- routes,
- scrollBehavior: (to, from, savedPosition) => {
- if (to.matched.some(m => m.meta.dontScroll)) {
- return false
- }
- return savedPosition || { x: 0, y: 0 }
- }
- })
-
- /* eslint-disable no-new */
- new Vue({
- router,
- store,
- i18n,
- el: '#app',
- render: h => h(App)
- })
- })
+ const user = state.users.currentUser
+ const isVapidMutation = mutation.type === 'setInstanceOption' && mutation.payload.name === 'vapidPublicKey'
-window.fetch('/static/terms-of-service.html')
- .then((res) => res.text())
- .then((html) => {
- store.dispatch('setOption', { name: 'tos', value: html })
- })
+ if (isVapidMutation && user && permission) {
+ return store.dispatch('registerPushNotifications')
+ }
-window.fetch('/api/pleroma/emoji.json')
- .then(
- (res) => res.json()
- .then(
- (values) => {
- const emoji = Object.keys(values).map((key) => {
- return { shortcode: key, image_url: values[key] }
- })
- store.dispatch('setOption', { name: 'customEmoji', value: emoji })
- store.dispatch('setOption', { name: 'pleromaBackend', value: true })
- },
- (failure) => {
- store.dispatch('setOption', { name: 'pleromaBackend', value: false })
- }
- ),
- (error) => console.log(error)
- )
-
-window.fetch('/static/emoji.json')
- .then((res) => res.json())
- .then((values) => {
- const emoji = Object.keys(values).map((key) => {
- return { shortcode: key, image_url: false, 'utf': values[key] }
- })
- store.dispatch('setOption', { name: 'emoji', value: emoji })
+ const isPermMutation = mutation.type === 'setNotificationPermission' && mutation.payload === 'granted'
+
+ if (isPermMutation && user && vapidPublicKey) {
+ return store.dispatch('registerPushNotifications')
+ }
})
+}
-window.fetch('/instance/panel.html')
- .then((res) => res.text())
- .then((html) => {
- store.dispatch('setOption', { name: 'instanceSpecificPanelContent', value: html })
+createPersistedState(persistedStateOptions).then((persistedState) => {
+ const store = new Vuex.Store({
+ modules: {
+ interface: interfaceModule,
+ instance: instanceModule,
+ statuses: statusesModule,
+ users: usersModule,
+ api: apiModule,
+ config: configModule,
+ chat: chatModule,
+ oauth: oauthModule
+ },
+ plugins: [persistedState, registerPushNotifications],
+ strict: false // Socket modifies itself, let's ignore this for now.
+ // strict: process.env.NODE_ENV !== 'production'
})
+ afterStoreSetup({ store, i18n })
+})
+
+// These are inlined by webpack's DefinePlugin
+/* eslint-disable */
+window.___pleromafe_mode = process.env
+window.___pleromafe_commit_hash = COMMIT_HASH
+window.___pleromafe_dev_overrides = DEV_OVERRIDES