mirror of
https://github.com/jech/galene.git
synced 2024-11-08 17:55:59 +01:00
Add dialog for generating tokens.
This commit is contained in:
parent
1afd995844
commit
2c852206bd
3 changed files with 102 additions and 1 deletions
|
@ -1337,3 +1337,7 @@ header .collapse:hover {
|
|||
margin-left: 10px;
|
||||
margin-right: 10px;
|
||||
}
|
||||
|
||||
#invite-dialog {
|
||||
background-color: #eee;
|
||||
}
|
||||
|
|
|
@ -281,6 +281,21 @@
|
|||
</div>
|
||||
</div>
|
||||
|
||||
<dialog id="invite-dialog">
|
||||
<form method="dialog">
|
||||
<label for="invite-username">Username (optional):</label>
|
||||
<input id="invite-username" type="text"/>
|
||||
<br>
|
||||
<label for="invite-not-before">Not before:</label>
|
||||
<input id="invite-not-before" type="datetime-local"/>
|
||||
<br>
|
||||
<label for="invite-expires">Expires:</label>
|
||||
<input id="invite-expires" type="datetime-local"/>
|
||||
<br>
|
||||
<button id="invite-cancel" value="cancel" type="button">Cancel</button>
|
||||
<button value="invite" value="invite">Invite</button>
|
||||
</dialog>
|
||||
|
||||
<script src="/protocol.js" defer></script>
|
||||
<script src="/external/toastify/toastify.js" defer></script>
|
||||
<script src="/external/contextual/contextual.js" defer></script>
|
||||
|
|
|
@ -2094,6 +2094,88 @@ function stringCompare(a, b) {
|
|||
return 0
|
||||
}
|
||||
|
||||
/**
|
||||
* @param {string} v
|
||||
*/
|
||||
function dateFromInput(v) {
|
||||
let d = new Date(v);
|
||||
if(d.toString() === 'Invalid Date')
|
||||
throw new Error('Invalid date');
|
||||
return d;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param {Date} d
|
||||
*/
|
||||
function dateToInput(d) {
|
||||
let dd = new Date(d);
|
||||
dd.setMinutes(dd.getMinutes() - dd.getTimezoneOffset());
|
||||
return dd.toISOString().slice(0, -1);
|
||||
}
|
||||
|
||||
function inviteMenu() {
|
||||
let d = /** @type {HTMLDialogElement} */
|
||||
(document.getElementById('invite-dialog'));
|
||||
if(!('HTMLDialogElement' in window) || !d.showModal) {
|
||||
makeToken();
|
||||
return;
|
||||
}
|
||||
d.returnValue = '';
|
||||
let c = getButtonElement('invite-cancel');
|
||||
c.onclick = function(e) { d.close('cancel'); };
|
||||
let u = getInputElement('invite-username');
|
||||
u.value = '';
|
||||
let now = new Date();
|
||||
now.setMilliseconds(0);
|
||||
now.setSeconds(0);
|
||||
let nb = getInputElement('invite-not-before');
|
||||
nb.min = dateToInput(now);
|
||||
let ex = getInputElement('invite-expires');
|
||||
let expires = new Date(now);
|
||||
expires.setDate(expires.getDate() + 2);
|
||||
ex.min = dateToInput(expires);
|
||||
ex.value = dateToInput(expires);
|
||||
d.showModal();
|
||||
}
|
||||
|
||||
document.getElementById('invite-dialog').onclose = function(e) {
|
||||
if(!(this instanceof HTMLDialogElement))
|
||||
throw new Error('Unexpected type for this');
|
||||
let dialog = /** @type {HTMLDialogElement} */(this);
|
||||
if(dialog.returnValue !== 'invite')
|
||||
return;
|
||||
let u = getInputElement('invite-username');
|
||||
let username = u.value.trim() || null;
|
||||
let nb = getInputElement('invite-not-before');
|
||||
let notBefore = null;
|
||||
if(nb.value) {
|
||||
try {
|
||||
notBefore = dateFromInput(nb.value);
|
||||
} catch(e) {
|
||||
displayError(`Couldn't parse ${nb.value}: ${e}`);
|
||||
return;
|
||||
}
|
||||
}
|
||||
let ex = getInputElement('invite-expires');
|
||||
let expires = null;
|
||||
if(ex.value) {
|
||||
try {
|
||||
expires = dateFromInput(ex.value);
|
||||
} catch(e) {
|
||||
displayError(`Couldn't parse ${nb.value}: ${e}`);
|
||||
return;
|
||||
}
|
||||
}
|
||||
let template = {}
|
||||
if(username)
|
||||
template.username = username;
|
||||
if(notBefore)
|
||||
template['not-before'] = notBefore;
|
||||
if(expires)
|
||||
template.expires = expires;
|
||||
makeToken(template);
|
||||
};
|
||||
|
||||
/**
|
||||
* @param {HTMLElement} elt
|
||||
*/
|
||||
|
@ -2122,7 +2204,7 @@ function userMenu(elt) {
|
|||
if(serverConnection.version !== "1" &&
|
||||
serverConnection.permissions.indexOf('token') >= 0) {
|
||||
items.push({label: 'Invite user', onClick: () => {
|
||||
makeToken();
|
||||
inviteMenu();
|
||||
}});
|
||||
}
|
||||
if(serverConnection.permissions.indexOf('present') >= 0 && canFile())
|
||||
|
|
Loading…
Reference in a new issue