analytics/assets/js/dashboard/query.js

67 lines
1.8 KiB
JavaScript
Raw Normal View History

2019-12-18 06:15:31 +03:00
import {formatDay, formatMonthYYYY, nowInOffset, parseUTCDate} from './date'
const PERIODS = ['realtime', 'day', 'month', '7d', '30d', '60d', '6mo', '12mo', 'custom']
export function parseQuery(querystring, site) {
const q = new URLSearchParams(querystring)
let period = q.get('period')
const periodKey = 'period__' + site.domain
if (PERIODS.includes(period)) {
if (period !== 'custom' && period !== 'realtime') window.localStorage[periodKey] = period
} else {
if (window.localStorage[periodKey]) {
period = window.localStorage[periodKey]
} else {
2019-11-19 07:44:54 +03:00
period = '30d'
}
}
return {
period: period,
2019-12-18 06:15:31 +03:00
date: q.get('date') ? parseUTCDate(q.get('date')) : nowInOffset(site.offset),
from: q.get('from') ? parseUTCDate(q.get('from')) : undefined,
to: q.get('to') ? parseUTCDate(q.get('to')) : undefined,
filters: {
'goal': q.get('goal'),
'source': q.get('source'),
'referrer': q.get('referrer')
}
}
}
export function toHuman(query) {
if (query.period === 'day') {
return `on ${formatDay(query.date)}`
} else if (query.period === 'month') {
return `in ${formatMonthYYYY(query.date)}`
} else if (query.period === '7d') {
return 'in the last 7 days'
} else if (query.period === '30d') {
return 'in the last 30 days'
2020-01-08 12:23:03 +03:00
} else if (query.period === '60d') {
return 'in the last 60 days'
2020-01-08 12:25:46 +03:00
} else if (query.period === '6mo') {
return 'in the last 6 months'
2020-01-08 12:23:03 +03:00
} else if (query.period === '12mo') {
2020-01-08 12:31:58 +03:00
return 'in the last 12 months'
}
}
export function removeQueryParam(search, parameter) {
const q = new URLSearchParams(search)
q.delete(parameter)
return q.toString()
}
export function eventName(query) {
if (query.filters.goal) {
if (query.filters.goal.startsWith('Visit ')) {
return 'pageviews'
}
return 'events'
} else {
return 'pageviews'
}
}