-
Notifications
You must be signed in to change notification settings - Fork 43
Expand file tree
/
Copy pathConvertkitForm.astro
More file actions
97 lines (86 loc) · 2.77 KB
/
ConvertkitForm.astro
File metadata and controls
97 lines (86 loc) · 2.77 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
<script is:inline>
const queryParams = new URLSearchParams(window.location.search)
const form = document.querySelector(".formkit-sticky-bar")
const fromNewsletter = queryParams.get("fromNewsletter")
if (fromNewsletter === "true") {
queryParams.delete("fromNewsletter")
const stringifiedParams = queryParams.toString()
history.replaceState(
null,
null,
`${location.pathname}${stringifiedParams ? `?${queryParams.toString()}` : ""
}${location.hash}`
)
localStorage.setItem("subscribed-to-newsletter", true)
}
if (fromNewsletter === "false") {
queryParams.delete("fromNewsletter")
const stringifiedParams = queryParams.toString()
history.replaceState(
null,
null,
`${location.pathname}${stringifiedParams ? `?${queryParams.toString()}` : ""
}${location.hash}`
)
localStorage.removeItem("subscribed-to-newsletter")
localStorage.removeItem("date-of-last-newsletter-link")
}
if (
localStorage.getItem("subscribed-to-newsletter") === "true" &&
localStorage.getItem("date-of-last-newsletter-link") == null
) {
localStorage.setItem("date-of-last-newsletter-link", new Date())
}
function dateWithinLast30Days(date) {
const today = new Date()
const timeDiff = Math.abs(today.getTime() - date.getTime())
const diffDays = timeDiff / (1000 * 3600 * 24)
return diffDays <= 30
}
const dateStringOfLastNewsletterLink = localStorage.getItem(
"date-of-last-newsletter-link"
)
if (
dateStringOfLastNewsletterLink != null &&
!dateWithinLast30Days(new Date(dateStringOfLastNewsletterLink))
) {
localStorage.removeItem("subscribed-to-newsletter")
localStorage.removeItem("date-of-last-newsletter-link")
}
if (
form == null &&
JSON.parse(localStorage.getItem("subscribed-to-newsletter")) !== true &&
JSON.parse(sessionStorage.getItem("form-closed")) !== true
) {
const script = document.createElement("script")
script.src = "https://web-dev-simplified.ck.page/23989b36d2/index.js"
script.async = true
script.dataset.uid = "23989b36d2"
const observer = new MutationObserver(entries => {
entries.forEach(entry => {
const formElem = [...entry.addedNodes].find(node => {
if (node.matches == null) return
return node.matches(".formkit-sticky-bar")
})
if (formElem == null) return
formElem.addEventListener("transitionend", () => {
if (
formElem.dataset.active == null ||
formElem.dataset.active === "false"
) {
formElem.remove()
}
})
document.body.prepend(formElem)
observer.disconnect()
})
})
observer.observe(document.body, { childList: true })
document.body.append(script)
}
document.addEventListener("click", e => {
if (e.target.matches("[data-formkit-close]")) {
sessionStorage.setItem("form-closed", true)
}
})
</script>