web/ProcessingStatus: refactor to svelte 5 & add aria label

This commit is contained in:
wukko 2025-05-14 22:41:55 +06:00
parent 773d771c40
commit 294273e2a7
No known key found for this signature in database
GPG Key ID: 3E30B3F26C7B4AA2
2 changed files with 28 additions and 5 deletions

View File

@ -0,0 +1,5 @@
{
"status.default": "processing queue",
"status.completed": "processing queue. all tasks are completed.",
"status.ongoing": "processing queue. ongoing tasks."
}

View File

@ -1,19 +1,37 @@
<script lang="ts">
import { t } from "$lib/i18n/translations";
import IconArrowDown from "@tabler/icons-svelte/IconArrowDown.svelte";
export let indeterminate = false;
export let progress: number = 0;
export let expandAction: () => void;
type Props = {
indeterminate?: boolean;
progress?: number;
expandAction: () => void;
}
$: progressStroke = `${progress}, 100`;
let {
indeterminate = false,
progress = $bindable(0),
expandAction
}: Props = $props();
let progressStroke = $derived(`${progress}, 100`);
const indeterminateStroke = "15, 5";
let ariaState = $derived(
progress > 0 && progress < 100
? "ongoing"
: progress >= 100
? "completed"
: "default"
)
</script>
<button
id="processing-status"
on:click={expandAction}
onclick={expandAction}
class="button"
class:completed={progress >= 100}
aria-label={$t(`a11y.queue.status.${ariaState}`)}
>
<svg
id="progress-ring"