mirror of
https://github.com/plausible/analytics.git
synced 2024-12-28 12:01:39 +03:00
fede2f0a8a
* Make final touches to Imports & Exports * Change import content copy depending on CSV imports and exports flag state * Remove unused aliases
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)}
|
|
/>
|
|
<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>
|