send/app/ui/signupDialog.js

62 lines
2 KiB
JavaScript
Raw Normal View History

2018-10-25 02:07:10 +00:00
/* global LIMITS */
const html = require('choo/html');
const { bytes } = require('../utils');
module.exports = function() {
return function(state, emit, close) {
setTimeout(function() {
document.getElementById('email-input').focus();
});
2018-10-25 02:07:10 +00:00
return html`
<send-signup-dialog class="flex flex-col p-4">
2018-10-25 02:07:10 +00:00
<p class="p-8">
${state.translate('accountBenefitTitle')}
2018-11-02 09:27:59 +00:00
<ul class="my-2 leading-normal">
2018-10-25 02:07:10 +00:00
<li>${state.translate('accountBenefitLargeFiles', {
size: bytes(LIMITS.MAX_FILE_SIZE)
})}</li>
<li>${state.translate('accountBenefitExpiry')}</li>
<li>${state.translate('accountBenefitSync')}</li>
</ul>
</p>
<form
onsubmit=${submitEmail}
data-no-csrf>
<input
id="email-input"
type="text"
2018-11-02 09:27:59 +00:00
class="border rounded w-full px-2 py-1 h-12 mb-4 text-lg text-grey-darker leading-loose"
2018-10-25 02:07:10 +00:00
placeholder=${state.translate('emailEntryPlaceholder')}/>
<input
class="hidden"
id="email-submit"
type="submit"/>
</form>
2018-11-02 09:27:59 +00:00
<label class="rounded bg-blue hover\:bg-blue-dark focus\:bg-blue-darker cursor-pointer text-center text-white py-2 px-6 h-12 w-full flex flex-no-shrink items-center justify-center font-semibold" for="email-submit">
2018-10-25 02:07:10 +00:00
${state.translate('signInMenuOption')}
</label>
<button
2018-11-02 09:27:59 +00:00
class="my-4 text-blue font-medium"
2018-10-25 02:07:10 +00:00
title="${state.translate('deletePopupCancel')}"
onclick=${close}>${state.translate('deletePopupCancel')}
</button>
</send-signup-dialog>`;
2018-10-25 02:07:10 +00:00
function emailish(str) {
if (!str) {
return false;
}
// just check if it's the right shape
const a = str.split('@');
return a.length === 2 && a.every(s => s.length > 0);
}
2018-10-25 02:07:10 +00:00
function submitEmail(event) {
event.preventDefault();
const el = document.getElementById('email-input');
const email = el.value;
emit('login', emailish(email) ? email : null);
2018-10-25 02:07:10 +00:00
}
};
};