fix finalize and unsubscribe pages by making them use new api module

pull/15/head
Brian Picciano 3 years ago
parent 15ae483fad
commit 3e9a17abb9
  1. 42
      static/src/mailinglist/finalize.md
  2. 41
      static/src/mailinglist/unsubscribe.md

@ -4,6 +4,8 @@ title: ""
nofollow: true nofollow: true
--- ---
<script async type="module" src="/assets/api.js"></script>
<style> <style>
#result.success { color: green; } #result.success { color: green; }
#result.fail { color: red; } #result.fail { color: red; }
@ -14,39 +16,29 @@ nofollow: true
<script> <script>
(async () => { (async () => {
const resultSpan = document.getElementById("result"); const resultSpan = document.getElementById("result");
function setErr(errStr) {
resultSpan.className = "fail";
resultSpan.innerHTML = errStr;
}
const urlParams = new URLSearchParams(window.location.search); try {
const subToken = urlParams.get('subToken');
if (!subToken) { const urlParams = new URLSearchParams(window.location.search);
setErr("No subscription token provided"); const subToken = urlParams.get('subToken');
return;
}
const finalizeForm = new FormData(); if (!subToken) throw "No subscription token provided";
finalizeForm.append('subToken', subToken);
const finalizeReq = new Request('/api/mailinglist/finalize', { const api = await import("/assets/api.js");
method: 'POST',
body: finalizeForm,
});
const res = await fetch(finalizeReq) await api.call('POST', '/api/mailinglist/finalize', {
.then(response => response.json()); body: { subToken },
});
if (res.error) { resultSpan.className = "success";
setErr(res.error); resultSpan.innerHTML = "Your email subscription has been finalized! Please go on about your day.";
return;
}
resultSpan.className = "success"; } catch (e) {
resultSpan.innerHTML = "Your email subscription has been finalized! Please go on about your day."; resultSpan.className = "fail";
resultSpan.innerHTML = e;
}
})(); })();

@ -4,6 +4,8 @@ title: ""
nofollow: true nofollow: true
--- ---
<script async type="module" src="/assets/api.js"></script>
<style> <style>
#result.success { color: green; } #result.success { color: green; }
#result.fail { color: red; } #result.fail { color: red; }
@ -14,40 +16,29 @@ nofollow: true
<script> <script>
(async () => { (async () => {
const resultSpan = document.getElementById("result"); const resultSpan = document.getElementById("result");
function setErr(errStr) { try {
resultSpan.className = "fail"; const urlParams = new URLSearchParams(window.location.search);
resultSpan.innerHTML = errStr; const unsubToken = urlParams.get('unsubToken');
}
const urlParams = new URLSearchParams(window.location.search); if (!unsubToken) throw "No unsubscribe token provided";
const unsubToken = urlParams.get('unsubToken');
if (!unsubToken) { const api = await import("/assets/api.js");
setErr("No unsubscribe token provided");
return;
}
const unsubscribeForm = new FormData();
unsubscribeForm.append('unsubToken', unsubToken);
const unsubscribeReq = new Request('/api/mailinglist/unsubscribe', { await api.call('POST', '/api/mailinglist/unsubscribe', {
method: 'POST', body: { unsubToken },
body: unsubscribeForm, });
});
const res = await fetch(unsubscribeReq) resultSpan.className = "success";
.then(response => response.json()); resultSpan.innerHTML = "You have been unsubscribed! Please go on about your day.";
if (res.error) { } catch (e) {
setErr(res.error); resultSpan.className = "fail";
return; resultSpan.innerHTML = e;
} }
resultSpan.className = "success";
resultSpan.innerHTML = "You have been unsubscribed! Please go on about your day.";
})(); })();
</script> </script>

Loading…
Cancel
Save