mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-20 22:42:53 -05:00
7e27b1cb36
closes https://linear.app/tryghost/issue/ANAL-58/click-through-filtering-for-content closes https://linear.app/tryghost/issue/ANAL-60/click-through-filtering-for-sources closes https://linear.app/tryghost/issue/ANAL-61/click-through-filtering-for-locations - This implements filtering and click-throughs for device, browser, source, location and pathname. - It requires significant updates to our tinybird setup, to pass through all the right data and have them as parameters on the API endpoints - We update the UI to add query parameters when clicking around and then pass those through to every chart/request. - We've added a interface to display the filters and remove them --------- Co-authored-by: Peter Zimon <peter.zimon@gmail.com>
44 lines
2 KiB
Text
44 lines
2 KiB
Text
|
|
DESCRIPTION >
|
|
Top Device Types ordered by most visits.
|
|
Accepts `date_from` and `date_to` date filter. Defaults to last 7 days.
|
|
Also `skip` and `limit` parameters for pagination.
|
|
|
|
TOKEN "dashboard" READ
|
|
TOKEN "stats page" READ
|
|
|
|
NODE endpoint
|
|
DESCRIPTION >
|
|
Group by device and calculate hits and visits
|
|
|
|
SQL >
|
|
%
|
|
select device, uniqMerge(visits) as visits, countMerge(hits) as hits
|
|
from analytics_sources_mv
|
|
where
|
|
site_uuid = {{String(site_uuid, 'mock_site_uuid', description="Tenant ID", required=True)}}
|
|
|
|
{% if defined(date_from) %}
|
|
and date
|
|
>=
|
|
{{ Date(date_from, description="Starting day for filtering a date range", required=False) }}
|
|
{% else %}
|
|
and date >= timestampAdd(today(), interval -7 day)
|
|
{% end %}
|
|
{% if defined(date_to) %}
|
|
and date
|
|
<=
|
|
{{ Date(date_to, description="Finishing day for filtering a date range", required=False) }}
|
|
{% else %} and date <= today()
|
|
{% end %}
|
|
|
|
{% if defined(member_status) %} and member_status IN {{ Array(member_status, "'undefined', 'free', 'paid'", description="Member status to filter on", required=False) }} {% end %}
|
|
{% if defined(device) %} and device = {{ String(device, description="Device to filter on", required=False) }} {% end %}
|
|
{% if defined(browser) %} and browser = {{ String(browser, description="Browser to filter on", required=False) }} {% end %}
|
|
{% if defined(source) %} and source = {{ String(source, description="Source to filter on", required=False) }} {% end %}
|
|
{% if defined(location) %} and location = {{ String(location, description="Location to filter on", required=False) }} {% end %}
|
|
{% if defined(pathname) %} and pathname = {{ String(pathname, description="Pathname to filter on", required=False) }} {% end %}
|
|
|
|
group by device
|
|
order by visits desc
|
|
limit {{ Int32(skip, 0) }},{{ Int32(limit, 50) }}
|