mirror of
https://github.com/hrfee/jfa-go.git
synced 2024-12-22 17:10:10 +00:00
invites: improve inv dropdown layout
This commit is contained in:
parent
f460bfcfc6
commit
202ee0977e
22
css/base.css
22
css/base.css
@ -219,23 +219,10 @@ sup.\~critical, .text-critical {
|
|||||||
font-size: 1rem;
|
font-size: 1rem;
|
||||||
}
|
}
|
||||||
|
|
||||||
.inv-created-users strong,p {
|
|
||||||
padding-left: 0.5rem;
|
|
||||||
padding-bottom: 0.2rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.inv-created-users.empty strong,p {
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.inv {
|
.inv {
|
||||||
overflow: visible;
|
overflow: visible;
|
||||||
}
|
}
|
||||||
|
|
||||||
.inv-table {
|
|
||||||
font-size: 0.8rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.inv-profilearea {
|
.inv-profilearea {
|
||||||
min-width: 20%;
|
min-width: 20%;
|
||||||
}
|
}
|
||||||
@ -416,7 +403,16 @@ table {
|
|||||||
color: var(--color-content);
|
color: var(--color-content);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
table.table.manual-pad th, table.table.manual-pad td {
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
table.table-p-0 th, table.table-p-0 td {
|
||||||
|
padding-left: 0 !important;
|
||||||
|
padding-right: 0 !important;
|
||||||
|
padding-top: 0 !important;
|
||||||
|
padding-bottom: 0 !important;
|
||||||
|
}
|
||||||
|
|
||||||
p.top {
|
p.top {
|
||||||
margin-top: 0px;
|
margin-top: 0px;
|
||||||
|
@ -549,11 +549,11 @@
|
|||||||
<div id="tab-invites">
|
<div id="tab-invites">
|
||||||
<div class="card @low invites dark:~d_neutral mb-4 overflow-visible">
|
<div class="card @low invites dark:~d_neutral mb-4 overflow-visible">
|
||||||
<span class="heading">{{ .strings.invites }}</span>
|
<span class="heading">{{ .strings.invites }}</span>
|
||||||
<div id="invites"></div>
|
<div id="invites" class="mt-2"></div>
|
||||||
</div>
|
</div>
|
||||||
<div class="card @low dark:~d_neutral">
|
<div class="card @low dark:~d_neutral">
|
||||||
<span class="heading">{{ .strings.create }}</span>
|
<span class="heading">{{ .strings.create }}</span>
|
||||||
<div class="flex flex-col md:flex-row gap-3" id="create-inv">
|
<div class="flex flex-col md:flex-row gap-3 mt-2" id="create-inv">
|
||||||
<div class="card ~neutral @low flex flex-col gap-2 w-1/2">
|
<div class="card ~neutral @low flex flex-col gap-2 w-1/2">
|
||||||
<div class="flex flex-row gap-2">
|
<div class="flex flex-row gap-2">
|
||||||
<label class="w-1/2">
|
<label class="w-1/2">
|
||||||
|
@ -146,10 +146,11 @@ class DOMInvite implements Invite {
|
|||||||
}
|
}
|
||||||
this._right.classList.remove("empty");
|
this._right.classList.remove("empty");
|
||||||
let innerHTML = `
|
let innerHTML = `
|
||||||
<table class="table inv-table">
|
<table class="table inv-table table-p-0">
|
||||||
<thead>
|
<thead>
|
||||||
<tr>
|
<tr>
|
||||||
<th>${window.lang.strings("name")}</th>
|
<th>${window.lang.strings("name")}</th>
|
||||||
|
<th class="w-2"></th>
|
||||||
<th>${window.lang.strings("date")}</th>
|
<th>${window.lang.strings("date")}</th>
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
@ -159,6 +160,7 @@ class DOMInvite implements Invite {
|
|||||||
innerHTML += `
|
innerHTML += `
|
||||||
<tr>
|
<tr>
|
||||||
<td>${username}</td>
|
<td>${username}</td>
|
||||||
|
<td class="w-2"></td>
|
||||||
<td>${toDateString(new Date(uB[username] * 1000))}</td>
|
<td>${toDateString(new Date(uB[username] * 1000))}</td>
|
||||||
</tr>
|
</tr>
|
||||||
`;
|
`;
|
||||||
@ -327,14 +329,17 @@ class DOMInvite implements Invite {
|
|||||||
|
|
||||||
this._details = document.createElement('div') as HTMLDivElement;
|
this._details = document.createElement('div') as HTMLDivElement;
|
||||||
this._container.appendChild(this._details);
|
this._container.appendChild(this._details);
|
||||||
this._details.classList.add("card", "~neutral", "@low", "mt-2", "no-pad", "inv-details");
|
this._details.classList.add("card", "~neutral", "@low", "mt-2", "inv-details");
|
||||||
const detailsInner = document.createElement('div') as HTMLDivElement;
|
const detailsInner = document.createElement('div') as HTMLDivElement;
|
||||||
this._details.appendChild(detailsInner);
|
this._details.appendChild(detailsInner);
|
||||||
detailsInner.classList.add("inv-row", "flex-expand", "row", "elem-pad", "align-top");
|
detailsInner.classList.add("inv-row", "flex", "flex-row", "justify-between", "align-top");
|
||||||
|
|
||||||
this._left = document.createElement('div') as HTMLDivElement;
|
this._left = document.createElement('div') as HTMLDivElement;
|
||||||
|
this._left.classList.add("flex", "flex-row", "gap-4");
|
||||||
detailsInner.appendChild(this._left);
|
detailsInner.appendChild(this._left);
|
||||||
this._left.classList.add("inv-profilearea");
|
const leftLeft = document.createElement("div") as HTMLDivElement;
|
||||||
|
this._left.appendChild(leftLeft);
|
||||||
|
leftLeft.classList.add("inv-profilearea");
|
||||||
let innerHTML = `
|
let innerHTML = `
|
||||||
<p class="supra mb-2 top">${window.lang.strings("profile")}</p>
|
<p class="supra mb-2 top">${window.lang.strings("profile")}</p>
|
||||||
<div class="select ~neutral @low inv-profileselect inline-block mb-2">
|
<div class="select ~neutral @low inv-profileselect inline-block mb-2">
|
||||||
@ -356,7 +361,7 @@ class DOMInvite implements Invite {
|
|||||||
</label>
|
</label>
|
||||||
`;
|
`;
|
||||||
}
|
}
|
||||||
this._left.innerHTML = innerHTML;
|
leftLeft.innerHTML = innerHTML;
|
||||||
(this._left.querySelector("select") as HTMLSelectElement).onchange = this.updateProfile;
|
(this._left.querySelector("select") as HTMLSelectElement).onchange = this.updateProfile;
|
||||||
|
|
||||||
if (window.notificationsEnabled) {
|
if (window.notificationsEnabled) {
|
||||||
@ -368,20 +373,21 @@ class DOMInvite implements Invite {
|
|||||||
}
|
}
|
||||||
|
|
||||||
this._middle = document.createElement('div') as HTMLDivElement;
|
this._middle = document.createElement('div') as HTMLDivElement;
|
||||||
detailsInner.appendChild(this._middle);
|
this._left.appendChild(this._middle);
|
||||||
this._middle.classList.add("block");
|
this._middle.classList.add("flex", "flex-col", "justify-between");
|
||||||
this._middle.innerHTML = `
|
this._middle.innerHTML = `
|
||||||
<p class="supra mb-4 top">${window.lang.strings("inviteDateCreated")} <strong class="inv-created"></strong></p>
|
<p class="supra top">${window.lang.strings("inviteDateCreated")} <strong class="inv-created"></strong></p>
|
||||||
<p class="supra mb-4">${window.lang.strings("inviteRemainingUses")} <strong class="inv-remaining"></strong></p>
|
<p class="supra">${window.lang.strings("inviteRemainingUses")} <strong class="inv-remaining"></strong></p>
|
||||||
<p class="supra mb-4"><span class="user-expiry"></span> <strong class="user-expiry-time"></strong></p>
|
<p class="supra"><span class="user-expiry"></span> <strong class="user-expiry-time"></strong></p>
|
||||||
<p class="mb-4 flex items-center"><span class="user-label-label supra mr-2"></span> <span class="user-label chip ~blue unfocused"></span></p>
|
<p class="flex items-center"><span class="user-label-label supra mr-2"></span> <span class="user-label chip ~blue unfocused"></span></p>
|
||||||
`;
|
`;
|
||||||
|
|
||||||
this._right = document.createElement('div') as HTMLDivElement;
|
this._right = document.createElement('div') as HTMLDivElement;
|
||||||
detailsInner.appendChild(this._right);
|
detailsInner.appendChild(this._right);
|
||||||
this._right.classList.add("card", "~neutral", "@low", "inv-created-users");
|
this._right.classList.add("card", "~neutral", "@low", "inv-created-users");
|
||||||
this._right.innerHTML = `<strong class="supra table-header">${window.lang.strings("inviteUsersCreated")}</strong>`;
|
this._right.innerHTML = `<span class="supra table-header">${window.lang.strings("inviteUsersCreated")}</span>`;
|
||||||
this._userTable = document.createElement('div') as HTMLDivElement;
|
this._userTable = document.createElement('div') as HTMLDivElement;
|
||||||
|
this._userTable.classList.add("text-sm", "mt-1");
|
||||||
this._right.appendChild(this._userTable);
|
this._right.appendChild(this._userTable);
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user