gancio/store/index.js

74 lines
2.1 KiB
JavaScript

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: []
},
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 = events
}
}
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)
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)
},
async getEvents ({ commit, state }, params = {}) {
const events = await this.$api.getEvents({
start: params.start || dayjs().startOf('month').unix(),
end: params.end || null,
show_recurrent: params.show_recurrent || state.settings.recurrent_event_visible
})
commit('setEvents', events)
return events
}
}