export const state = () => ({ locale: '', user_locale: {}, filters: { tags: [], places: [], show_recurrent: false }, tags: [], places: [], settings: { instance_timezone: 'Europe/Rome', instance_name: '', allow_registration: true, allow_anon_event: true, allow_recurrent_event: true, recurrent_event_visible: false, enable_federation: false, enable_resources: false, hide_boosts: true, enable_trusted_instances: true, trusted_instances: [], footerLinks: [] }, announcements: [] }) export const mutations = { update (state, { tags, places }) { state.tags = tags state.places = places }, setSettings (state, settings) { state.settings = settings state.filters.show_recurrent = settings.recurrent_event_visible }, setSetting (state, setting) { state.settings[setting.key] = setting.value }, setLocale (state, locale) { state.locale = locale }, setUserlocale (state, messages) { state.user_locale = messages }, setFilters (state, filters) { state.filters.tags = [...filters.tags] state.filters.places = [...filters.places] state.filters.show_recurrent = filters.show_recurrent }, setAnnouncements (state, announcements) { state.announcements = announcements } } export const actions = { // this method is called server side only for each request for nuxt // we use it to get configuration from db, set locale, etc... nuxtServerInit ({ commit }, { req }) { commit('setSettings', req.settings) if (!req.firstrun) { commit('setAnnouncements', req.announcements) commit('update', req.meta) } }, async updateAnnouncements ({ commit }) { const announcements = await this.$axios.$get('/announcements') commit('setAnnouncements', announcements) }, async updateMeta ({ commit }) { const { tags, places } = await this.$axios.$get('/event/meta') commit('update', { tags, places }) }, setFilters ({ commit }, filters) { commit('setFilters', filters) }, setAnnouncements ({ commit }, announcements) { commit('setAnnouncements', announcements) }, async setSetting ({ commit }, setting) { await this.$axios.$post('/settings', setting) commit('setSetting', setting) } }