import dayjs from 'dayjs' export const state = () => ({ settings: { instance_timezone: 'Europe/Rome', instance_name: '', allow_registration: true, allow_anon_event: true, allow_multidate_event: true, allow_recurrent_event: true, recurrent_event_visible: false, allow_geolocation: false, geocoding_provider_type: '', geocoding_provider: '', geocoding_countrycodes: [], tilelayer_provider: '', tilelayer_provider_attribution: '', enable_federation: false, enable_resources: false, hide_boosts: true, enable_trusted_instances: true, trusted_instances: [], trusted_instances_label: '', footerLinks: [] }, filter: { query: '', show_recurrent: null, show_multidate: null, }, announcements: [], events: [] }) export const mutations = { setSettings (state, settings) { state.settings = settings }, setSetting (state, setting) { state.settings[setting.key] = setting.value }, setAnnouncements (state, announcements) { state.announcements = announcements }, setEvents (state, events) { state.events = Object.freeze(events) }, setFilter (state, { type, value }) { state.filter[type] = value } } 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, res }) { commit('setSettings', res.locals.settings) commit('setFilter', { type: 'show_recurrent', value: res.locals.settings.allow_recurrent_event && res.locals.settings.recurrent_event_visible }) if (res.locals.status === 'READY') { commit('setAnnouncements', res.locals.announcements) } }, async updateAnnouncements ({ commit }) { const announcements = await this.$axios.$get('/announcements') commit('setAnnouncements', announcements) }, setAnnouncements ({ commit }, announcements) { commit('setAnnouncements', announcements) }, async setSetting ({ commit }, setting) { await this.$axios.$post('/settings', setting) commit('setSetting', setting) }, setFilter ({ commit }, [type, value]) { commit('setFilter', { type, value }) }, async getEvents ({ commit, state }, params = {}) { const events = await this.$api.getEvents({ start: params.start || dayjs().startOf('month').unix(), end: params.end || null, show_recurrent: state.filter.show_recurrent, show_multidate: state.filter.show_multidate }) commit('setEvents', events) } }