mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-20 22:42:53 -05:00
🎨 Reused attribution for embeddable signup forms on own site
fixes https://github.com/TryGhost/Team/issues/3473 When a signup happens via the embeddable signup form on your own site, we'll use the default attribution, so it indistinguishable from a signup via Portal.
This commit is contained in:
parent
998708c81a
commit
4da658e72a
3 changed files with 42 additions and 2 deletions
|
@ -869,6 +869,7 @@ export const transformApiTiersData = ({tiers}) => {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the member attribution URL history, which is stored in localStorage, if there is any.
|
* Returns the member attribution URL history, which is stored in localStorage, if there is any.
|
||||||
|
* @warning If you make changes here, please also update the one in signup-form!
|
||||||
* @returns {Object[]|undefined}
|
* @returns {Object[]|undefined}
|
||||||
*/
|
*/
|
||||||
export function getUrlHistory() {
|
export function getUrlHistory() {
|
||||||
|
|
|
@ -19,7 +19,7 @@ export const setupGhostApi = ({siteUrl}: {siteUrl: string}) => {
|
||||||
email,
|
email,
|
||||||
emailType: 'signup',
|
emailType: 'signup',
|
||||||
labels,
|
labels,
|
||||||
urlHistory: getUrlHistory()
|
urlHistory: getUrlHistory({siteUrl})
|
||||||
});
|
});
|
||||||
|
|
||||||
const response = await fetch(url, {
|
const response = await fetch(url, {
|
||||||
|
|
|
@ -13,7 +13,46 @@ export function isMinimal(options: SignupFormOptions): boolean {
|
||||||
return !options.title;
|
return !options.title;
|
||||||
}
|
}
|
||||||
|
|
||||||
export function getUrlHistory(): URLHistory {
|
/**
|
||||||
|
* Get the URL history when the form is embedded on the site itself.
|
||||||
|
*/
|
||||||
|
export function getDefaultUrlHistory() {
|
||||||
|
const STORAGE_KEY = 'ghost-history';
|
||||||
|
|
||||||
|
try {
|
||||||
|
const historyString = localStorage.getItem(STORAGE_KEY);
|
||||||
|
if (historyString) {
|
||||||
|
const parsed = JSON.parse(historyString);
|
||||||
|
|
||||||
|
if (Array.isArray(parsed)) {
|
||||||
|
return parsed;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
// Failed to access localStorage or something related to that.
|
||||||
|
// Log a warning, as this shouldn't happen on a modern browser.
|
||||||
|
|
||||||
|
/* eslint-disable no-console */
|
||||||
|
console.warn(`[Signup-Form] Failed to load member URL history:`, error);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export function getUrlHistory({siteUrl}: {siteUrl: string}): URLHistory {
|
||||||
|
// If we are embedded on the site itself, use the default attribution localStorage, just like Portal
|
||||||
|
try {
|
||||||
|
if (window.location.host === new URL(siteUrl).host) {
|
||||||
|
const history = getDefaultUrlHistory();
|
||||||
|
if (history) {
|
||||||
|
return history;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
// Most likely an invalid siteUrl
|
||||||
|
|
||||||
|
/* eslint-disable no-console */
|
||||||
|
console.warn(`[Signup-Form] Failed to load member URL history:`, error);
|
||||||
|
}
|
||||||
|
|
||||||
const history: URLHistory = [];
|
const history: URLHistory = [];
|
||||||
|
|
||||||
// Href without query string
|
// Href without query string
|
||||||
|
|
Loading…
Add table
Reference in a new issue