mirror of
https://github.com/plausible/analytics.git
synced 2024-12-29 20:42:01 +03:00
2cc80ebd7a
* Extend the Tokens context module * Extract GA Import to separate component * Extract Search Console settings to separate component * Remove Search Console from the router * Stop counting imported pageviews in general settings * Remove search console controller action * Add settings_integrations controller action * Fix remaining redirects * Add Integrations route * Replace SC sidebar item with Integrations * Update site controller tests * Implement Plugins API Tokens LV * Apply universal heroicon to docs info links * Add flash on token creation * Update CHANGELOG * Redirect to integrations upon forgetting GA import * Update moduledocs * Remove unnecessary wildcards * WIP: attempt at fixing broken oauth flow * Fix post-import redirect * Fixup missing attribute * Format * Seed random google auth * Use example.com for seeded e-mails * Tweak Google integrations layout * Remove dangling IO.inspect * Bugfix: copy to clipboard breaking LV form bindings * Update lib/plausible/plugins/api/tokens.ex Co-authored-by: Adrian Gruntkowski <adrian.gruntkowski@gmail.com> * Update lib/plausible_web/controllers/site_controller.ex Co-authored-by: Adrian Gruntkowski <adrian.gruntkowski@gmail.com> * Update lib/plausible_web/live/plugins/api/settings.ex Co-authored-by: Adrian Gruntkowski <adrian.gruntkowski@gmail.com> * Update test/plausible/plugins/api/tokens_test.exs Co-authored-by: Adrian Gruntkowski <adrian.gruntkowski@gmail.com> --------- Co-authored-by: Adrian Gruntkowski <adrian.gruntkowski@gmail.com>
128 lines
5.7 KiB
Plaintext
128 lines
5.7 KiB
Plaintext
<div class="shadow bg-white dark:bg-gray-800 sm:rounded-md sm:overflow-hidden py-6 px-4 sm:p-6">
|
|
<header class="relative border-b border-gray-200 pb-4">
|
|
<h2 class="text-lg leading-6 font-medium text-gray-900 dark:text-gray-100">
|
|
Google Search Console Integration
|
|
</h2>
|
|
<p class="mt-1 text-sm leading-5 text-gray-500 dark:text-gray-200">
|
|
You can integrate with Google Search Console to get all of your important search results stats such as keyword phrases people find your site with.
|
|
</p>
|
|
|
|
<PlausibleWeb.Components.Generic.docs_info slug="google-search-console-integration" />
|
|
</header>
|
|
|
|
<%= if Keyword.get(Application.get_env(:plausible, :google), :client_id) do %>
|
|
<%= if @site.google_auth do %>
|
|
<div class="flex py-8">
|
|
<span class="flex-1 text-gray-700 dark:text-gray-300">
|
|
Linked Google account: <b><%= @site.google_auth.email %></b>
|
|
</span>
|
|
|
|
<%= link("Unlink Google account",
|
|
to: "/#{URI.encode_www_form(@site.domain)}/settings/google-search",
|
|
class:
|
|
"inline-block px-4 text-sm leading-5 font-medium text-red-600 bg-white dark:bg-gray-800 hover:text-red-500 dark:hover:text-red-400 focus:outline-none focus:ring active:text-red-800 active:bg-gray-50 transition ease-in-out duration-150",
|
|
method: "delete"
|
|
) %>
|
|
</div>
|
|
|
|
<%= case @search_console_domains do %>
|
|
<% {:ok, domains} -> %>
|
|
<%= if @site.google_auth.property && !(@site.google_auth.property in domains) do %>
|
|
<p class="text-gray-700 dark:text-gray-300 mt-6 font-bold">
|
|
NB: Your Google account does not have access to your currently configured property, <%= @site.google_auth.property %>. Please select a verified property from the list below.
|
|
</p>
|
|
<% else %>
|
|
<p class="text-gray-700 dark:text-gray-300 mt-6">
|
|
Select the Google Search Console property you would like to pull keyword data from. If you don't see your domain,
|
|
<.styled_link
|
|
href="https://plausible.io/docs/google-search-console-integration"
|
|
new_tab={true}
|
|
>
|
|
set it up and verify
|
|
</.styled_link>
|
|
on Search Console first.
|
|
</p>
|
|
<% end %>
|
|
|
|
<%= form_for Plausible.Site.GoogleAuth.changeset(@site.google_auth), "/#{URI.encode_www_form(@site.domain)}/settings/google", [class: "max-w-xs"], fn f -> %>
|
|
<div class="my-6">
|
|
<div class="inline-block relative w-full">
|
|
<%= select(f, :property, domains,
|
|
prompt: "(Choose property)",
|
|
class:
|
|
"dark:bg-gray-800 mt-1 block w-full pl-3 pr-10 py-2 text-base border-gray-300 dark:border-gray-500 outline-none focus:outline-none focus:ring-indigo-500 focus:border-indigo-500 sm:text-sm rounded-md dark:text-gray-100"
|
|
) %>
|
|
</div>
|
|
</div>
|
|
|
|
<%= submit("Save", class: "button") %>
|
|
<% end %>
|
|
<% {:error, error} -> %>
|
|
<p class="text-gray-700 dark:text-gray-300 mt-6">
|
|
The following error happened when fetching your Google Search Console domains:
|
|
</p>
|
|
|
|
<%= case error do %>
|
|
<% "invalid_grant" -> %>
|
|
<p class="text-red-700 font-medium mt-3">
|
|
<a href="https://plausible.io/docs/google-search-console-integration#i-get-the-invalid-grant-error">
|
|
Invalid Grant error returned from Google. <span class="text-indigo-500">See here on how to fix it</span>.
|
|
</a>
|
|
</p>
|
|
<% "google_auth_error" -> %>
|
|
<p class="text-red-700 font-medium mt-3">
|
|
Your Search Console account hasn't been connected successfully. Please unlink your Google account and try linking it again.
|
|
</p>
|
|
<% _ -> %>
|
|
<p class="text-red-700 font-medium mt-3">
|
|
Something went wrong, but looks temporary. If the problem persists, try re-linking your Google account.
|
|
</p>
|
|
<% end %>
|
|
<% end %>
|
|
<% else %>
|
|
<PlausibleWeb.Components.Google.button
|
|
id="search-console-connect"
|
|
to={Plausible.Google.Api.search_console_authorize_url(@site.id, "search-console")}
|
|
/>
|
|
<div class="text-gray-700 dark:text-gray-300 mt-8">
|
|
NB: You also need to set up your site on
|
|
<.styled_link href="https://search.google.com/search-console/about" new_tab={true}>
|
|
Google Search Console
|
|
</.styled_link>
|
|
for the integration to work.
|
|
<.styled_link
|
|
href="https://plausible.io/docs/google-search-console-integration"
|
|
new_tab={true}
|
|
>
|
|
Read the docs
|
|
</.styled_link>,
|
|
</div>
|
|
<% end %>
|
|
<% else %>
|
|
<div class="my-8 text-center text-lg">
|
|
<svg
|
|
class="block mx-auto mb-4 w-6 h-6 text-yellow-500"
|
|
fill="none"
|
|
stroke="currentColor"
|
|
viewBox="0 0 24 24"
|
|
xmlns="http://www.w3.org/2000/svg"
|
|
>
|
|
<path
|
|
stroke-linecap="round"
|
|
stroke-linejoin="round"
|
|
stroke-width="2"
|
|
d="M12 9v2m0 4h.01m-6.938 4h13.856c1.54 0 2.502-1.667 1.732-3L13.732 4c-.77-1.333-2.694-1.333-3.464 0L3.34 16c-.77 1.333.192 3 1.732 3z"
|
|
>
|
|
</path>
|
|
</svg>
|
|
<p class="text-gray-900 dark:text-gray-200">
|
|
An extra step is needed to set up your Plausible Analytics Self Hosted for the Google Search Console integration.
|
|
Find instructions <%= link("here",
|
|
to: "https://plausible.io/docs/self-hosting-configuration#google-search-integration",
|
|
class: "text-indigo-500"
|
|
) %>
|
|
</p>
|
|
</div>
|
|
<% end %>
|
|
</div>
|