gradio
1<script lang="ts">
2export let layout = "bubble";
3</script>
4
5<div
6class="message pending"
7role="status"
8aria-label="Loading response"
9aria-live="polite"
10style:border-radius={layout === "bubble" ? "var(--radius-xxl)" : "none"}
11>
12<span class="sr-only">Loading content</span>
13<div class="dot-flashing" />
14
15<div class="dot-flashing" />
16
17<div class="dot-flashing" />
18</div>
19
20<style>
21.pending {
22background: var(--color-accent-soft);
23display: flex;
24flex-direction: row;
25justify-content: center;
26align-items: center;
27align-self: center;
28gap: 2px;
29width: 100%;
30height: var(--size-16);
31}
32.dot-flashing {
33animation: flash 1s infinite ease-in-out;
34border-radius: 5px;
35background-color: var(--body-text-color);
36width: 7px;
37height: 7px;
38color: var(--body-text-color);
39}
40@keyframes flash {
410%,
42100% {
43opacity: 0;
44}
4550% {
46opacity: 1;
47}
48}
49
50.dot-flashing:nth-child(1) {
51animation-delay: 0s;
52}
53
54.dot-flashing:nth-child(2) {
55animation-delay: 0.33s;
56}
57.dot-flashing:nth-child(3) {
58animation-delay: 0.66s;
59}
60</style>
61