[fix] ~ #38
This commit is contained in:
parent
1a62db59b0
commit
a743281e59
6 changed files with 27 additions and 28 deletions
|
@ -114,7 +114,7 @@
|
||||||
import { mapActions, mapState, mapGetters } from 'vuex'
|
import { mapActions, mapState, mapGetters } from 'vuex'
|
||||||
import uniq from 'lodash/uniq'
|
import uniq from 'lodash/uniq'
|
||||||
import map from 'lodash/map'
|
import map from 'lodash/map'
|
||||||
import moment from 'dayjs'
|
import moment from 'moment'
|
||||||
|
|
||||||
import List from '@/components/List'
|
import List from '@/components/List'
|
||||||
import { Message } from 'element-ui'
|
import { Message } from 'element-ui'
|
||||||
|
@ -252,7 +252,7 @@ export default {
|
||||||
return this.events.filter(e =>
|
return this.events.filter(e =>
|
||||||
!e.multidate
|
!e.multidate
|
||||||
? date_start.isSame(moment.unix(e.start_datetime), 'day') ||
|
? date_start.isSame(moment.unix(e.start_datetime), 'day') ||
|
||||||
date_start.isBefore(moment.unix(e.start_datime)) && date_end.isAfter(moment.unix(e.start_datetime))
|
date_start.isBefore(moment.unix(e.start_dateime)) && date_end.isAfter(moment.unix(e.start_datetime))
|
||||||
: date_start.isSame(moment.unix(e.start_datetime), 'day') || date_start.isSame(moment.unix(e.end_datetime)) ||
|
: date_start.isSame(moment.unix(e.start_datetime), 'day') || date_start.isSame(moment.unix(e.end_datetime)) ||
|
||||||
date_start.isAfter(moment.unix(e.start_datetime)) && date_start.isBefore(moment.unix(e.end_datetime)))
|
date_start.isAfter(moment.unix(e.start_datetime)) && date_start.isBefore(moment.unix(e.end_datetime)))
|
||||||
} else if (this.event.type === 'recurrent') {
|
} else if (this.event.type === 'recurrent') {
|
||||||
|
@ -268,6 +268,7 @@ export default {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
...mapGetters(['filteredEvents']),
|
...mapGetters(['filteredEvents']),
|
||||||
|
// TOFIX
|
||||||
attributes () {
|
attributes () {
|
||||||
let attributes = []
|
let attributes = []
|
||||||
attributes.push({ key: 'today', dates: new Date(), highlight: { color: 'yellow' } })
|
attributes.push({ key: 'today', dates: new Date(), highlight: { color: 'yellow' } })
|
||||||
|
@ -389,8 +390,8 @@ export default {
|
||||||
formData.append('place_address', this.event.place.address)
|
formData.append('place_address', this.event.place.address)
|
||||||
formData.append('description', this.event.description)
|
formData.append('description', this.event.description)
|
||||||
formData.append('multidate', this.event.type === 'multidate')
|
formData.append('multidate', this.event.type === 'multidate')
|
||||||
formData.append('start_datetime', start_datetime.unix())
|
formData.append('start_datetime', start_datetime.utc(true).unix())
|
||||||
formData.append('end_datetime', end_datetime.unix())
|
formData.append('end_datetime', end_datetime.utc(true).unix())
|
||||||
|
|
||||||
if (this.edit) {
|
if (this.edit) {
|
||||||
formData.append('id', this.event.id)
|
formData.append('id', this.event.id)
|
||||||
|
|
|
@ -1,29 +1,30 @@
|
||||||
import Vue from 'vue'
|
import Vue from 'vue'
|
||||||
import moment from 'dayjs'
|
import moment from 'moment'
|
||||||
import 'dayjs/locale/it'
|
// import 'dayjs/locale/it'
|
||||||
import 'dayjs/locale/es'
|
// import 'dayjs/locale/es'
|
||||||
|
|
||||||
export default ({ app, store }) => {
|
export default ({ app, store }) => {
|
||||||
// replace links with anchors
|
// replace links with anchors
|
||||||
// TODO: remove fb tracking id
|
// TODO: remove fb tracking id
|
||||||
Vue.filter('linkify', value => value.replace(/(https?:\/\/[^\s]+)/g, '<a href="$1">$1</a>'))
|
Vue.filter('linkify', value => value.replace(/(https?:\/\/[^\s]+)/g, '<a href="$1">$1</a>'))
|
||||||
Vue.filter('url2host', url => url.match(/^https?:\/\/(.[^/:]+)/i)[1])
|
Vue.filter('url2host', url => url.match(/^https?:\/\/(.[^/:]+)/i)[1])
|
||||||
Vue.filter('datetime', value => moment(value).locale(store.state.locale).format('ddd, D MMMM HH:mm'))
|
Vue.filter('datetime', value => moment(value).utc(false).locale(store.state.locale).format('ddd, D MMMM HH:mm'))
|
||||||
// Vue.filter('short_datetime', value => moment(value).locale(store.state.locale).format('D/MM HH:mm'))
|
// Vue.filter('short_datetime', value => moment(value).locale(store.state.locale).format('D/MM HH:mm'))
|
||||||
// Vue.filter('hour', value => moment(value).locale(store.state.locale).format('HH:mm'))
|
// Vue.filter('hour', value => moment(value).locale(store.state.locale).format('HH:mm'))
|
||||||
|
|
||||||
// shown in mobile homepage
|
// shown in mobile homepage
|
||||||
Vue.filter('day', value => moment.unix(value).locale(store.state.locale).format('dddd, D MMM'))
|
Vue.filter('day', value => moment.unix(value).utc(false).locale(store.state.locale).format('dddd, D MMM'))
|
||||||
// Vue.filter('month', value => moment(value).locale(store.state.locale).format('MMM'))
|
// Vue.filter('month', value => moment(value).locale(store.state.locale).format('MMM'))
|
||||||
|
|
||||||
// format event start/end datetime based on page
|
// format event start/end datetime based on page
|
||||||
Vue.filter('when', (event, where) => {
|
Vue.filter('when', (event, where) => {
|
||||||
moment.locale(store.state.locale)
|
moment.locale(store.state.locale)
|
||||||
|
|
||||||
// {start,end}_datetime are unix timestamp
|
// show local time relative to event's place
|
||||||
const start = moment.unix(event.start_datetime)
|
// (not where in the worlds I'm looking at the page from)
|
||||||
const end = moment.unix(event.end_datetime)
|
const start = moment.unix(event.start_datetime).utc(false)
|
||||||
|
const end = moment.unix(event.end_datetime).utc(false)
|
||||||
|
|
||||||
const normal = `${start.format('dddd, D MMMM (HH:mm-')}${end.format('HH:mm)')}`
|
const normal = `${start.format('dddd, D MMMM (HH:mm-')}${end.format('HH:mm)')}`
|
||||||
|
|
||||||
// recurrent event
|
// recurrent event
|
||||||
|
|
|
@ -188,11 +188,13 @@ const eventController = {
|
||||||
.month(req.params.month)
|
.month(req.params.month)
|
||||||
.startOf('month')
|
.startOf('month')
|
||||||
.startOf('week')
|
.startOf('week')
|
||||||
|
.utc(false)
|
||||||
|
|
||||||
let end = moment()
|
let end = moment()
|
||||||
.year(req.params.year)
|
.year(req.params.year)
|
||||||
.month(req.params.month)
|
.month(req.params.month)
|
||||||
.endOf('month')
|
.endOf('month')
|
||||||
|
.utc(false)
|
||||||
|
|
||||||
const shownDays = end.diff(start, 'days')
|
const shownDays = end.diff(start, 'days')
|
||||||
if (shownDays <= 35) { end = end.add(1, 'week') }
|
if (shownDays <= 35) { end = end.add(1, 'week') }
|
||||||
|
@ -231,7 +233,7 @@ const eventController = {
|
||||||
if (!recurrent.frequency) { return false }
|
if (!recurrent.frequency) { return false }
|
||||||
|
|
||||||
let cursor = moment(start).startOf('week')
|
let cursor = moment(start).startOf('week')
|
||||||
const start_date = moment.unix(e.start_datetime)
|
const start_date = moment.unix(e.start_datetime).utc(false)
|
||||||
const duration = moment.unix(e.end_datetime).diff(start_date, 's')
|
const duration = moment.unix(e.end_datetime).diff(start_date, 's')
|
||||||
const frequency = recurrent.frequency
|
const frequency = recurrent.frequency
|
||||||
const days = recurrent.days
|
const days = recurrent.days
|
||||||
|
@ -239,7 +241,6 @@ const eventController = {
|
||||||
|
|
||||||
// default frequency is '1d' => each day
|
// default frequency is '1d' => each day
|
||||||
const toAdd = { n: 1, unit: 'day' }
|
const toAdd = { n: 1, unit: 'day' }
|
||||||
cursor.set('hour', start_date.hour()).set('minute', start_date.minutes())
|
|
||||||
|
|
||||||
// each week or 2 (search for the first specified day)
|
// each week or 2 (search for the first specified day)
|
||||||
if (frequency === '1w' || frequency === '2w') {
|
if (frequency === '1w' || frequency === '2w') {
|
||||||
|
@ -253,6 +254,8 @@ const eventController = {
|
||||||
// cursor.set('hour', start_date.hour()).set('minute', start_date.minutes())
|
// cursor.set('hour', start_date.hour()).set('minute', start_date.minutes())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
cursor.set('hour', start_date.hour()).set('minute', start_date.minutes())
|
||||||
|
|
||||||
// each month or 2
|
// each month or 2
|
||||||
if (frequency === '1m' || frequency === '2m') {
|
if (frequency === '1m' || frequency === '2m') {
|
||||||
// find first match
|
// find first match
|
||||||
|
@ -275,12 +278,13 @@ const eventController = {
|
||||||
cursor.day(d - 1)
|
cursor.day(d - 1)
|
||||||
}
|
}
|
||||||
if (cursor.isAfter(dueTo) || cursor.isBefore(start)) { return }
|
if (cursor.isAfter(dueTo) || cursor.isBefore(start)) { return }
|
||||||
e.start_datetime = cursor.unix()
|
e.start_datetime = cursor.utc(true).unix()
|
||||||
e.end_datetime = e.start_datetime + duration
|
e.end_datetime = e.start_datetime + duration
|
||||||
events.push(Object.assign({}, e))
|
events.push(Object.assign({}, e))
|
||||||
})
|
})
|
||||||
if (cursor.isAfter(dueTo)) { break }
|
if (cursor.isAfter(dueTo)) { break }
|
||||||
cursor = first_event_of_week.add(toAdd.n, toAdd.unit)
|
cursor = first_event_of_week.add(toAdd.n, toAdd.unit)
|
||||||
|
cursor.set('hour', start_date.hour()).set('minute', start_date.minutes())
|
||||||
}
|
}
|
||||||
|
|
||||||
return events
|
return events
|
||||||
|
|
|
@ -51,8 +51,8 @@ const exportController = {
|
||||||
|
|
||||||
ics (res, events) {
|
ics (res, events) {
|
||||||
const eventsMap = events.map(e => {
|
const eventsMap = events.map(e => {
|
||||||
const tmpStart = moment.unix(e.start_datetime)
|
const tmpStart = moment.unix(e.start_datetime).utc(false)
|
||||||
const tmpEnd = moment.unix(e.end_datetime)
|
const tmpEnd = moment.unix(e.end_datetime).utc(false)
|
||||||
const start = [tmpStart.year(), tmpStart.month() + 1, tmpStart.date(), tmpStart.hour(), tmpStart.minute()]
|
const start = [tmpStart.year(), tmpStart.month() + 1, tmpStart.date(), tmpStart.hour(), tmpStart.minute()]
|
||||||
const end = [tmpEnd.year(), tmpEnd.month() + 1, tmpEnd.date(), tmpEnd.hour(), tmpEnd.minute()]
|
const end = [tmpEnd.year(), tmpEnd.month() + 1, tmpEnd.date(), tmpEnd.hour(), tmpEnd.minute()]
|
||||||
return {
|
return {
|
||||||
|
|
|
@ -36,13 +36,12 @@ module.exports = (sequelize, DataTypes) => {
|
||||||
event.hasMany(models.comment)
|
event.hasMany(models.comment)
|
||||||
}
|
}
|
||||||
|
|
||||||
//
|
|
||||||
event.prototype.toAP = function (username, follower = []) {
|
event.prototype.toAP = function (username, follower = []) {
|
||||||
const tags = this.tags && this.tags.map(t => `<a href='/tags/${t.tag}' class='mention hashtag' rel='tag'>#${t.tag}</a>`).join(' ')
|
const tags = this.tags && this.tags.map(t => `<a href='/tags/${t.tag}' class='mention hashtag' rel='tag'>#${t.tag}</a>`).join(' ')
|
||||||
|
|
||||||
const content = `<a href='${config.baseurl}/event/${this.id}'>${this.title}</a><br/>
|
const content = `<a href='${config.baseurl}/event/${this.id}'>${this.title}</a><br/>
|
||||||
📍${this.place.name}<br/>
|
📍${this.place.name}<br/>
|
||||||
⏰ ${moment.unix(this.start_datetime).format('dddd, D MMMM (HH:mm)')}<br/><br/>
|
⏰ ${moment.unix(this.start_datetime).utc(false).format('dddd, D MMMM (HH:mm)')}<br/><br/>
|
||||||
${this.description.length > 200 ? this.description.substr(0, 200) + '...' : this.description}<br/>
|
${this.description.length > 200 ? this.description.substr(0, 200) + '...' : this.description}<br/>
|
||||||
${tags} <br/>`
|
${tags} <br/>`
|
||||||
|
|
||||||
|
@ -74,12 +73,6 @@ module.exports = (sequelize, DataTypes) => {
|
||||||
content,
|
content,
|
||||||
summary: null,
|
summary: null,
|
||||||
sensitive: false,
|
sensitive: false,
|
||||||
startTime: moment.unix(this.start_datetime),
|
|
||||||
location: {
|
|
||||||
type: 'Place',
|
|
||||||
name: this.place.name,
|
|
||||||
address: this.place.address
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -7,13 +7,13 @@ rss(version='2.0')
|
||||||
language #{config.locale}
|
language #{config.locale}
|
||||||
each event in events
|
each event in events
|
||||||
item
|
item
|
||||||
title [#{moment.unix(event.start_datetime).format("YY-MM-DD")}] #{event.title} @#{event.place.name}
|
title [#{moment.unix(event.start_datetime).utc(false).format("YY-MM-DD")}] #{event.title} @#{event.place.name}
|
||||||
link #{config.baseurl}/event/#{event.id}
|
link #{config.baseurl}/event/#{event.id}
|
||||||
description
|
description
|
||||||
| <![CDATA[
|
| <![CDATA[
|
||||||
| <h4>#{event.title}</h4>
|
| <h4>#{event.title}</h4>
|
||||||
| <strong>#{event.place.name} - #{event.place.address}</strong>
|
| <strong>#{event.place.name} - #{event.place.address}</strong>
|
||||||
| <small>(#{moment.unix(event.start_datetime).format("dddd, D MMMM HH:mm")})</small><br/>
|
| <small>(#{moment.unix(event.start_datetime).utc(false).format("dddd, D MMMM HH:mm")})</small><br/>
|
||||||
if (event.image_path)
|
if (event.image_path)
|
||||||
| <img src="#{config.apiurl}/media/#{event.image_path}"/>
|
| <img src="#{config.apiurl}/media/#{event.image_path}"/>
|
||||||
| <pre>!{event.description}</pre>
|
| <pre>!{event.description}</pre>
|
||||||
|
|
Loading…
Reference in a new issue