mirror of
https://github.com/wassname/template.git
synced 2026-06-27 17:50:45 +08:00
Improve interstitial behavior
Remove if no password during pre-render Remove if no password during onFrontMatterChanged Remove self if on production host
This commit is contained in:
@@ -3,6 +3,7 @@ import { Template } from '../mixins/template';
|
||||
// This overlay is not secure.
|
||||
// It is only meant as a social deterrent.
|
||||
|
||||
const productionHostname = 'distill.pub';
|
||||
const T = Template('d-interstitial', `
|
||||
<style>
|
||||
|
||||
@@ -109,13 +110,11 @@ p small {
|
||||
export class Interstitial extends T(HTMLElement) {
|
||||
|
||||
connectedCallback() {
|
||||
const passwordInput = this.root.querySelector('#interstitial-password-input');
|
||||
passwordInput.oninput = (event) => this.passwordChanged(event);
|
||||
if (typeof(Storage) !== 'undefined') {
|
||||
if (localStorage.getItem('distill-interstitial-password-correct') === 'true') {
|
||||
console.log('Loaded that correct password was entered before; skipping interstitial.');
|
||||
this.parentElement.removeChild(this);
|
||||
}
|
||||
if (this.shouldRemoveSelf()) {
|
||||
this.parentElement.removeChild(this);
|
||||
} else {
|
||||
const passwordInput = this.root.querySelector('#interstitial-password-input');
|
||||
passwordInput.oninput = (event) => this.passwordChanged(event);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -126,9 +125,32 @@ export class Interstitial extends T(HTMLElement) {
|
||||
this.parentElement.removeChild(this);
|
||||
if (typeof(Storage) !== 'undefined') {
|
||||
console.log('Saved that correct password was entered.');
|
||||
localStorage.setItem('distill-interstitial-password-correct', 'true');
|
||||
localStorage.setItem(this.localStorageIdentifier(), 'true');
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
shouldRemoveSelf() {
|
||||
// should never be visible in production
|
||||
if (window && window.location.hostname === productionHostname) {
|
||||
console.warn('Interstitial found on production, hiding it.');
|
||||
return true
|
||||
}
|
||||
// should only have to enter password once
|
||||
if (typeof(Storage) !== 'undefined') {
|
||||
if (localStorage.getItem(this.localStorageIdentifier()) === 'true') {
|
||||
console.log('Loaded that correct password was entered before; skipping interstitial.');
|
||||
return true;
|
||||
}
|
||||
}
|
||||
// otherwise, leave visible
|
||||
return false;
|
||||
}
|
||||
|
||||
localStorageIdentifier() {
|
||||
const prefix = 'distill-drafts'
|
||||
const suffix = 'interstitial-password-correct';
|
||||
return prefix + (window ? window.location.pathname : '-') + suffix
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
+5
-1
@@ -120,7 +120,11 @@ export const Controller = {
|
||||
|
||||
const interstitial = document.querySelector('d-interstitial');
|
||||
if (interstitial) {
|
||||
interstitial.password = frontMatter.password;
|
||||
if (typeof frontMatter.password !== 'undefined') {
|
||||
interstitial.password = frontMatter.password;
|
||||
} else {
|
||||
interstitial.parentElement.removeChild(interstitial);
|
||||
}
|
||||
}
|
||||
|
||||
const prerendered = document.body.hasAttribute('distill-prerendered');
|
||||
|
||||
@@ -50,6 +50,8 @@ export default function(dom, data) {
|
||||
interstitial.password = data.password;
|
||||
body.insertBefore(interstitial, body.firstChild);
|
||||
}
|
||||
} else if (!hasPassword && interstitial) {
|
||||
interstitial.parentElement.removeChild(this);
|
||||
}
|
||||
|
||||
let appendix = dom.querySelector('d-appendix');
|
||||
|
||||
Reference in New Issue
Block a user