2021-05-16 22:00:00 -07:00
<!DOCTYPE html>
2021-06-13 10:59:35 -07:00
< html lang = "en" >
2021-05-16 22:00:00 -07:00
< head >
< meta charset = "utf-8" >
< meta http-equiv = "X-UA-Compatible" content = "IE=edge" >
< title > Simple Contact< / title >
< meta name = "viewport" content = "width=device-width, initial-scale=1" >
<!-- water.dark.css -->
< style >
body{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.4;max-width:800px;margin:20px auto;padding:0 10px;color:#dbdbdb;background:#202b38;text-rendering:optimizeLegibility}button,input,textarea{transition:background-color .1s linear,border-color .1s linear,color .1s linear,box-shadow .1s linear,transform .1s ease}h1{font-size:2.2em;margin-top:0}h1,h2,h3,h4,h5,h6{margin-bottom:12px}h1,h2,h3,h4,h5,h6,strong{color:#fff}b,h1,h2,h3,h4,h5,h6,strong,th{font-weight:600}blockquote{border-left:4px solid rgba(0,150,191,.67);margin:1.5em 0;padding:.5em 1em;font-style:italic}blockquote>footer{margin-top:10px;font-style:normal}address,blockquote cite{font-style:normal}a[href^=mailto]:before{content:"📧 "}a[href^=tel]:before{content:"📞 "}a[href^=sms]:before{content:"💬 "}button,input[type=button],input[type=checkbox],input[type=submit]{cursor:pointer}input:not([type=checkbox]):not([type=radio]),select{display:block}button,input,select,textarea{color:#fff;background-color:#161f27;font-family:inherit;font-size:inherit;margin-right:6px;margin-bottom:6px;padding:10px;border:none;border-radius:6px;outline:none}button,input:not([type=checkbox]):not([type=radio]),select,textarea{-webkit-appearance:none}textarea{margin-right:0;width:100%;box-sizing:border-box;resize:vertical}button,input[type=button],input[type=submit]{padding-right:30px;padding-left:30px}button:hover,input[type=button]:hover,input[type=submit]:hover{background:#324759}button:focus,input:focus,select:focus,textarea:focus{box-shadow:0 0 0 2px rgba(0,150,191,.67)}button:active,input[type=button]:active,input[type=checkbox]:active,input[type=radio]:active,input[type=submit]:active{transform:translateY(2px)}button:disabled,input:disabled,select:disabled,textarea:disabled{cursor:not-allowed;opacity:.5}::-webkit-input-placeholder{color:#a9a9a9}:-ms-input-placeholder{color:#a9a9a9}::-ms-input-placeholder{color:#a9a9a9}::placeholder{color:#a9a9a9}a{text-decoration:none;color:#41adff}a:hover{text-decoration:underline}code,kbd{background:#161f27;color:#ffbe85;padding:5px;border-radius:6px}pre>code{padding:10px;display:block;overflow-x:auto}img{max-width:100%}hr{border:none;border-top:1px solid #dbdbdb}table{border-collapse:collapse;margin-bottom:10px;width:100%}td,th{padding:6px;text-align:left}th{border-bottom:1px solid #dbdbdb}tbody tr:nth-child(2n){background-color:#161f27}::-webkit-scrollbar{height:10px;width:10px}::-webkit-scrollbar-track{background:#161f27;border-radius:6px}::-webkit-scrollbar-thumb{background:#324759;border-radius:6px}::-webkit-scrollbar-thumb:hover{background:#415c73}
#message {
height: 200px;
}
< / style >
< / head >
< body >
< h1 > Simple Contact< / h1 >
< hr / >
< form action = "/" method = "POST" >
2021-06-08 00:00:01 -07:00
< textarea class = "formcache" required id = "message" name = "message" placeholder = "Message" > < / textarea >
2021-05-16 22:00:00 -07:00
< div style = "padding: 5px 0" >
2021-06-13 10:59:35 -07:00
< img src = "data:image/png;base64,{{ captcha_png }}" alt = "CAPTCHA image" / >
2021-05-16 22:00:00 -07:00
< / div >
< input required type = "text" name = "captcha-solution" placeholder = "CAPTCHA Solution" >
< input type = "hidden" name = "captcha-id" value = "{{ captcha_id }}" >
2021-06-08 00:00:01 -07:00
< noscript >
< p > < em > Works without JavaScript!< / em > < / p >
< / noscript >
2021-05-16 23:41:46 -07:00
< button type = "submit" > Submit< / button >
2021-05-16 22:00:00 -07:00
< / form >
< p > Source code available on < a target = "_blank" rel = "noopener noreferrer" href = "https://github.com/andrewkdinh/simple-contact" > GitHub< / a > and < a target = "_blank" rel = "noopener noreferrer" href = "https://gitea.andrewkdinh.com/andrewkdinh/simple-contact" > Gitea< / a > < / p >
< p > Licensed under < a target = "_blank" rel = "noopener noreferrer" href = "https://www.gnu.org/licenses/agpl-3.0.html" > AGPL 3.0< / a > | Styling with < a target = "_blank" rel = "noopener noreferrer" href = "https://github.com/kognise/water.css" > water.css< / a > < / p >
2021-06-08 00:00:01 -07:00
< script >
(function () {
// https://jlelse.blog/dev/form-cache-localstorage
const fc = 'formcache'
Array.from(document.querySelectorAll('form .' + fc)).forEach(element => {
let elementName = fc + '-' + location.pathname + '#' + element.id
// Load from cache
2021-06-08 00:26:23 -07:00
let cached = sessionStorage.getItem(elementName)
2021-06-08 00:00:01 -07:00
if (cached != null) {
element.value = cached
}
// Auto save to cache
element.addEventListener('input', function () {
2021-06-08 00:26:23 -07:00
sessionStorage.setItem(elementName, element.value)
2021-06-08 00:00:01 -07:00
})
})
})()
< / script >
2021-05-16 22:00:00 -07:00
< / body >
< / html >