gancio/plugins/filters.js

25 lines
1 KiB
JavaScript
Raw Normal View History

2019-04-03 00:25:12 +02:00
import Vue from 'vue'
import moment from 'dayjs'
import 'dayjs/locale/it'
2019-06-25 01:05:38 +02:00
export default ({ app, store }) => {
moment.locale(store.state.locale)
2019-05-30 12:12:51 +02:00
Vue.filter('linkify', value => value.replace(/(https?:\/\/[^\s]+)/g, '<a href="$1">$1</a>'))
2019-05-30 12:04:14 +02:00
Vue.filter('datetime', value => moment(value).format('ddd, D MMMM HH:mm'))
Vue.filter('short_datetime', value => moment(value).format('D/MM HH:mm'))
Vue.filter('hour', value => moment(value).format('HH:mm'))
Vue.filter('day', value => moment(value*1000).format('dddd, D MMMM'))
2019-05-30 12:04:14 +02:00
Vue.filter('month', value => moment(value).format('MMM'))
Vue.filter('event_when', event => {
const start = moment(event.start_datetime*1000)
const end = moment(event.end_datetime*1000)
2019-05-30 12:04:14 +02:00
if (event.multidate) {
2019-06-26 14:44:21 +02:00
return `${start.format('ddd, D MMMM (HH:mm)')} - ${end.format('ddd, D MMMM')}`
2019-06-07 17:02:33 +02:00
} else if (event.end_datetime && event.end_datetime !== event.start_datetime)
return `${start.format('ddd, D MMMM (HH:mm-')}${end.format('HH:mm)')}`
2019-05-30 12:04:14 +02:00
else
return start.format('dddd, D MMMM (HH:mm)')
2019-05-30 12:04:14 +02:00
})
2019-06-07 17:02:33 +02:00
}