[FE][Classroom] Fixes #17 - Add button to increase expiry date by 2 months
This commit is contained in:
parent
930c4ef56e
commit
8d8c5b0cca
@ -6,9 +6,11 @@ import { ArrowsClockwiseIcon } from "../../icons/ArrowsClockwiseIcon";
|
||||
import { JsonResult } from "../../types/JsonResult";
|
||||
import { AxiosError } from "axios";
|
||||
import { WarningIcon } from "../../icons/WarningIcon";
|
||||
import { PlusIcon } from "../../icons/PlusIcon";
|
||||
|
||||
export function AccountExpiration(props: {userId: number}) {
|
||||
const [expirationDate, setExpirationDate] = createSignal<string | null>(null); // YYYY-MM-DD
|
||||
const [localExpirationDate, setLocalExpirationDate] = createSignal<string | null>(null); // YYYY-MM-DD
|
||||
const {status, setStatus, error, setError} = useLoading();
|
||||
|
||||
const loading = createMemo(() => status() === LoadingStatus.Loading);
|
||||
@ -28,6 +30,7 @@ export function AccountExpiration(props: {userId: number}) {
|
||||
setError("");
|
||||
setStatus(LoadingStatus.Loading);
|
||||
setExpirationDate(null);
|
||||
setLocalExpirationDate(null);
|
||||
|
||||
backend.get<JsonResult<string>>(`/api/classroom/expiration_date/${props.userId}`)
|
||||
.then((response) => {
|
||||
@ -51,15 +54,25 @@ export function AccountExpiration(props: {userId: number}) {
|
||||
});
|
||||
};
|
||||
|
||||
const setExpiration2Months = () => {
|
||||
setStatus(LoadingStatus.Loading);
|
||||
const newDate = new Date();
|
||||
newDate.setDate(newDate.getDate() + 60);
|
||||
setLocalExpirationDate(newDate.toISOString().split("T")[0]);
|
||||
|
||||
setExpiration();
|
||||
};
|
||||
|
||||
const setExpiration = () => {
|
||||
setStatus(LoadingStatus.Loading);
|
||||
|
||||
backend.put<JsonResult<null>>(
|
||||
`/api/classroom/expiration_date/${props.userId}`,
|
||||
{date: expirationDate()},
|
||||
{date: localExpirationDate()},
|
||||
)
|
||||
.then((response) => {
|
||||
if (response.status === 200) {
|
||||
loadExpiration();
|
||||
setStatus(LoadingStatus.Ok);
|
||||
}
|
||||
})
|
||||
@ -72,7 +85,7 @@ export function AccountExpiration(props: {userId: number}) {
|
||||
onMount(loadExpiration);
|
||||
|
||||
return (
|
||||
<OutlinedCard class="w-[24rem] h-[10.5rem] overflow-hidden">
|
||||
<OutlinedCard class="w-[24rem] overflow-hidden">
|
||||
<h2 class="text-xl p-3 bg-c-surface-variant text-c-on-surface-variant">
|
||||
Fecha de expiración del acceso
|
||||
</h2>
|
||||
@ -106,55 +119,91 @@ export function AccountExpiration(props: {userId: number}) {
|
||||
</span>
|
||||
</p>
|
||||
|
||||
<p class="grid grid-cols-[auto_9rem] items-center">
|
||||
<span>
|
||||
Fecha de expiración:
|
||||
</span>
|
||||
<hr />
|
||||
|
||||
<input
|
||||
class="bg-c-surface text-c-on-surface border border-c-outline rounded-lg py-1 px-2 font-mono
|
||||
disabled:opacity-50 disabled:cursor-not-allowed"
|
||||
type="date"
|
||||
name="classroom-expiration-update"
|
||||
id="classroom-expiration-update"
|
||||
value={expirationDate() ?? ""}
|
||||
oninput={(e) => setExpirationDate(e.target.value)}
|
||||
disabled={status() === LoadingStatus.Loading}
|
||||
/>
|
||||
</p>
|
||||
<div class="grid grid-cols-2">
|
||||
<div class="border-r border-c-outline pt-2 pr-1">
|
||||
<p>Ampliar por preset:</p>
|
||||
|
||||
<button
|
||||
class="bg-c-primary text-c-on-primary px-3 py-2 rounded-full cursor-pointer
|
||||
disabled:opacity-50 disabled:cursor-not-allowed relative mt-[2.47rem]"
|
||||
type="button"
|
||||
disabled={loading()}
|
||||
onclick={setExpiration2Months}
|
||||
>
|
||||
<span class="mr-6">
|
||||
Agregar 2 meses
|
||||
</span>
|
||||
<span
|
||||
class="absolute top-1 right-2"
|
||||
style={{display: loading() ? "inline-block" : "none"}}
|
||||
>
|
||||
<LoadingIcon
|
||||
class="animate-spin"
|
||||
fill="var(--c-primary-container)"
|
||||
/>
|
||||
</span>
|
||||
<span
|
||||
class="absolute top-1 right-1"
|
||||
style={{display: loading() ? "none" : "inline-block"}}
|
||||
>
|
||||
<PlusIcon
|
||||
fill="var(--c-on-primary)"
|
||||
/>
|
||||
</span>
|
||||
</button>
|
||||
</div>
|
||||
<div class="pt-2 pl-1 text-right">
|
||||
<p>Ampliar manualmente:</p>
|
||||
|
||||
<input
|
||||
class="bg-c-surface text-c-on-surface border border-c-outline rounded-lg py-1 px-2 font-mono
|
||||
disabled:opacity-50 disabled:cursor-not-allowed my-1"
|
||||
type="date"
|
||||
name="classroom-expiration-update"
|
||||
id="classroom-expiration-update"
|
||||
value={localExpirationDate() ?? ""}
|
||||
oninput={(e) => setLocalExpirationDate(e.target.value)}
|
||||
disabled={status() === LoadingStatus.Loading}
|
||||
/>
|
||||
|
||||
<button
|
||||
class="bg-c-primary text-c-on-primary px-4 py-2 rounded-full cursor-pointer
|
||||
disabled:opacity-50 disabled:cursor-not-allowed relative"
|
||||
type="button"
|
||||
disabled={loading()}
|
||||
onclick={setExpiration}
|
||||
>
|
||||
<span class="mr-6">
|
||||
Actualizar
|
||||
</span>
|
||||
<span
|
||||
class="absolute top-1 right-2"
|
||||
style={{display: loading() ? "inline-block" : "none"}}
|
||||
>
|
||||
<LoadingIcon
|
||||
class="animate-spin"
|
||||
fill="var(--c-primary-container)"
|
||||
/>
|
||||
</span>
|
||||
<span
|
||||
class="absolute top-1 right-2"
|
||||
style={{display: loading() ? "none" : "inline-block"}}
|
||||
>
|
||||
<ArrowsClockwiseIcon
|
||||
fill="var(--c-on-primary)"
|
||||
/>
|
||||
</span>
|
||||
</button>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="pt-2 grid grid-cols-[auto_8.5rem] items-center gap-2">
|
||||
<span class="text-c-error">
|
||||
{error()}
|
||||
</span>
|
||||
<button
|
||||
class="bg-c-primary text-c-on-primary px-4 py-2 rounded-full cursor-pointer
|
||||
disabled:opacity-50 disabled:cursor-not-allowed relative"
|
||||
type="button"
|
||||
disabled={loading()}
|
||||
onclick={setExpiration}
|
||||
>
|
||||
<span class="mr-6">
|
||||
Actualizar
|
||||
</span>
|
||||
<span
|
||||
class="absolute top-1 right-2"
|
||||
style={{display: loading() ? "inline-block" : "none"}}
|
||||
>
|
||||
<LoadingIcon
|
||||
class="animate-spin"
|
||||
fill="var(--c-primary-container)"
|
||||
/>
|
||||
</span>
|
||||
<span
|
||||
class="absolute top-1 right-2"
|
||||
style={{display: loading() ? "none" : "inline-block"}}
|
||||
>
|
||||
<ArrowsClockwiseIcon
|
||||
fill="var(--c-on-primary)"
|
||||
/>
|
||||
</span>
|
||||
</button>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
|
15
frontend/src/icons/PlusIcon.tsx
Normal file
15
frontend/src/icons/PlusIcon.tsx
Normal file
@ -0,0 +1,15 @@
|
||||
|
||||
export function PlusIcon(props: {fill: string, size?: number, class?: string}) {
|
||||
return (
|
||||
<svg
|
||||
xmlns="http://www.w3.org/2000/svg"
|
||||
class={`inline-block w-6 ${props.class}`}
|
||||
width={props.size ?? 32}
|
||||
height={props.size ?? 32}
|
||||
fill={props.fill}
|
||||
viewBox="0 0 256 256"
|
||||
>
|
||||
<path d="M224,128a8,8,0,0,1-8,8H136v80a8,8,0,0,1-16,0V136H40a8,8,0,0,1,0-16h80V40a8,8,0,0,1,16,0v80h80A8,8,0,0,1,224,128Z" />
|
||||
</svg>
|
||||
);
|
||||
}
|
Loading…
Reference in New Issue
Block a user