mirror of
https://github.com/plausible/analytics.git
synced 2024-12-27 03:21:37 +03:00
Fix filter suggestions (#3265)
* Fix filter suggestions * Mute credo for now
This commit is contained in:
parent
20d31a8d0d
commit
e59cda5d93
@ -177,6 +177,7 @@ defmodule Plausible.Stats.FilterSuggestions do
|
||||
|> wrap_suggestions()
|
||||
end
|
||||
|
||||
# credo:disable-for-next-line Credo.Check.Refactor.CyclomaticComplexity
|
||||
def filter_suggestions(site, query, filter_name, filter_search) do
|
||||
filter_search = if filter_search == nil, do: "", else: filter_search
|
||||
|
||||
@ -187,109 +188,122 @@ defmodule Plausible.Stats.FilterSuggestions do
|
||||
|
||||
filter_name =
|
||||
case filter_name do
|
||||
"page" -> "pathname"
|
||||
"source" -> "referrer_source"
|
||||
"os" -> "operating_system"
|
||||
"os_version" -> "operating_system_version"
|
||||
"screen" -> "screen_size"
|
||||
_ -> filter_name
|
||||
"page" -> :pathname
|
||||
"entry_page" -> :entry_page
|
||||
"source" -> :referrer_source
|
||||
"os" -> :operating_system
|
||||
"os_version" -> :operating_system_version
|
||||
"screen" -> :screen_size
|
||||
"exit_page" -> :exit_page
|
||||
"utm_source" -> :utm_source
|
||||
"utm_medium" -> :utm_medium
|
||||
"utm_campaign" -> :utm_campaign
|
||||
"utm_content" -> :utm_content
|
||||
"utm_term" -> :utm_term
|
||||
"referrer" -> :referrer
|
||||
"browser" -> :browser
|
||||
"browser_version" -> :browser_version
|
||||
"operating_system" -> :operating_system
|
||||
"operating_system_version" -> :operating_system_version
|
||||
"screen_size" -> :screen_size
|
||||
_ -> :unknown
|
||||
end
|
||||
|
||||
q =
|
||||
if(filter_name == "pathname",
|
||||
if(filter_name == :pathname,
|
||||
do: base_event_query(site, query),
|
||||
else: query_sessions(site, query)
|
||||
)
|
||||
|> from(
|
||||
group_by: ^String.to_atom(filter_name),
|
||||
group_by: ^filter_name,
|
||||
order_by: [desc: fragment("count(*)")],
|
||||
limit: 25
|
||||
)
|
||||
|
||||
q =
|
||||
case filter_name do
|
||||
"pathname" ->
|
||||
:pathname ->
|
||||
from(e in q,
|
||||
select: e.pathname,
|
||||
where: fragment("? ilike ?", e.pathname, ^filter_query)
|
||||
)
|
||||
|
||||
"entry_page" ->
|
||||
:entry_page ->
|
||||
from(e in q,
|
||||
select: e.entry_page,
|
||||
where: fragment("? ilike ?", e.entry_page, ^filter_query)
|
||||
)
|
||||
|
||||
"exit_page" ->
|
||||
:exit_page ->
|
||||
from(e in q,
|
||||
select: e.exit_page,
|
||||
where: fragment("? ilike ?", e.exit_page, ^filter_query)
|
||||
)
|
||||
|
||||
"referrer_source" ->
|
||||
:referrer_source ->
|
||||
from(e in q,
|
||||
select: e.referrer_source,
|
||||
where: fragment("? ilike ?", e.referrer_source, ^filter_query)
|
||||
)
|
||||
|
||||
"utm_medium" ->
|
||||
:utm_medium ->
|
||||
from(e in q,
|
||||
select: e.utm_medium,
|
||||
where: fragment("? ilike ?", e.utm_medium, ^filter_query)
|
||||
)
|
||||
|
||||
"utm_source" ->
|
||||
:utm_source ->
|
||||
from(e in q,
|
||||
select: e.utm_source,
|
||||
where: fragment("? ilike ?", e.utm_source, ^filter_query)
|
||||
)
|
||||
|
||||
"utm_campaign" ->
|
||||
:utm_campaign ->
|
||||
from(e in q,
|
||||
select: e.utm_campaign,
|
||||
where: fragment("? ilike ?", e.utm_campaign, ^filter_query)
|
||||
)
|
||||
|
||||
"utm_content" ->
|
||||
:utm_content ->
|
||||
from(e in q,
|
||||
select: e.utm_content,
|
||||
where: fragment("? ilike ?", e.utm_content, ^filter_query)
|
||||
)
|
||||
|
||||
"utm_term" ->
|
||||
:utm_term ->
|
||||
from(e in q,
|
||||
select: e.utm_term,
|
||||
where: fragment("? ilike ?", e.utm_term, ^filter_query)
|
||||
)
|
||||
|
||||
"referrer" ->
|
||||
:referrer ->
|
||||
from(e in q,
|
||||
select: e.referrer,
|
||||
where: fragment("? ilike ?", e.referrer, ^filter_query)
|
||||
)
|
||||
|
||||
"browser" ->
|
||||
:browser ->
|
||||
from(e in q, select: e.browser, where: fragment("? ilike ?", e.browser, ^filter_query))
|
||||
|
||||
"browser_version" ->
|
||||
:browser_version ->
|
||||
from(e in q,
|
||||
select: e.browser_version,
|
||||
where: fragment("? ilike ?", e.browser_version, ^filter_query)
|
||||
)
|
||||
|
||||
"operating_system" ->
|
||||
:operating_system ->
|
||||
from(e in q,
|
||||
select: e.operating_system,
|
||||
where: fragment("? ilike ?", e.operating_system, ^filter_query)
|
||||
)
|
||||
|
||||
"operating_system_version" ->
|
||||
:operating_system_version ->
|
||||
from(e in q,
|
||||
select: e.operating_system_version,
|
||||
where: fragment("? ilike ?", e.operating_system_version, ^filter_query)
|
||||
)
|
||||
|
||||
"screen_size" ->
|
||||
:screen_size ->
|
||||
from(e in q,
|
||||
select: e.screen_size,
|
||||
where: fragment("? ilike ?", e.screen_size, ^filter_query)
|
||||
|
@ -121,8 +121,11 @@ defmodule PlausibleWeb.Api.ExternalStatsController do
|
||||
|> String.split(",")
|
||||
|
||||
case validate_all_metrics(metrics, property, query) do
|
||||
{:error, reason} -> {:error, reason}
|
||||
metrics -> {:ok, Enum.map(metrics, &String.to_atom/1)}
|
||||
{:error, reason} ->
|
||||
{:error, reason}
|
||||
|
||||
metrics ->
|
||||
{:ok, Enum.map(metrics, &String.to_existing_atom/1)}
|
||||
end
|
||||
end
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user