@ansiversa/components 0.0.94 → 0.0.96
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/index.ts +1 -0
- package/package.json +1 -1
- package/src/AvLoading.astro +15 -0
- package/src/AvTable.astro +5 -7
- package/src/styles/global.css +37 -0
package/index.ts
CHANGED
|
@@ -11,6 +11,7 @@ export { default as AvFeatureList } from './src/AvFeatureList.astro';
|
|
|
11
11
|
export { default as AvFooter } from './src/AvFooter.astro';
|
|
12
12
|
export { default as AvIcon } from './src/AvIcon.astro';
|
|
13
13
|
export { default as AvInput } from './src/AvInput.astro';
|
|
14
|
+
export { default as AvLoading } from './src/AvLoading.astro';
|
|
14
15
|
export { default as AvSelect } from './src/AvSelect.astro';
|
|
15
16
|
export { default as AvTextarea } from './src/AvTextarea.astro';
|
|
16
17
|
export { default as AvNavbar } from './src/AvNavbar.astro';
|
package/package.json
CHANGED
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
---
|
|
2
|
+
interface Props {
|
|
3
|
+
label?: string;
|
|
4
|
+
className?: string;
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
const { label = "Loading…", className = "", ...attrs } = Astro.props as Props & Record<string, unknown>;
|
|
8
|
+
---
|
|
9
|
+
|
|
10
|
+
<div class={`av-loading-overlay ${className}`} role="status" aria-live="polite" {...attrs}>
|
|
11
|
+
<div class="av-loading-panel">
|
|
12
|
+
<span class="av-loading-spinner" aria-hidden="true"></span>
|
|
13
|
+
<p class="av-text-soft av-m-0">{label}</p>
|
|
14
|
+
</div>
|
|
15
|
+
</div>
|
package/src/AvTable.astro
CHANGED
|
@@ -21,7 +21,6 @@ const {
|
|
|
21
21
|
} = Astro.props as Props & Record<string, unknown>;
|
|
22
22
|
|
|
23
23
|
const normalizedSortDir = sortDir === "asc" || sortDir === "desc" ? sortDir : undefined;
|
|
24
|
-
const tableId = `av-table-${Math.random().toString(36).slice(2, 10)}`;
|
|
25
24
|
const dataSortKey = "data-sort-key" in attrs ? undefined : sortKey;
|
|
26
25
|
const dataSortDir = "data-sort-dir" in attrs ? undefined : normalizedSortDir;
|
|
27
26
|
---
|
|
@@ -30,18 +29,16 @@ const dataSortDir = "data-sort-dir" in attrs ? undefined : normalizedSortDir;
|
|
|
30
29
|
class={`av-table ${scroll ? "av-table--scroll" : ""} ${dense ? "av-table--dense" : ""} ${stickyHeader ? "av-table--sticky" : ""} ${className}`}
|
|
31
30
|
data-sort-key={dataSortKey}
|
|
32
31
|
data-sort-dir={dataSortDir}
|
|
33
|
-
data-av-table-id={tableId}
|
|
34
32
|
{...attrs}
|
|
35
33
|
>
|
|
36
34
|
<table class="av-table__table">
|
|
37
35
|
{caption ? <caption class="av-table__caption">{caption}</caption> : null}
|
|
38
36
|
<slot />
|
|
39
37
|
</table>
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
<script define:vars={{ initialSortKey: sortKey ?? "", initialSortDir: normalizedSortDir ?? "", tableId }}>
|
|
38
|
+
<script define:vars={{ initialSortKey: sortKey ?? "", initialSortDir: normalizedSortDir ?? "" }}>
|
|
43
39
|
(() => {
|
|
44
|
-
const
|
|
40
|
+
const script = document.currentScript;
|
|
41
|
+
const root = script?.closest?.(".av-table");
|
|
45
42
|
if (!root) return;
|
|
46
43
|
|
|
47
44
|
const controls = Array.from(root.querySelectorAll("[data-av-sort]"));
|
|
@@ -100,10 +97,11 @@ const dataSortDir = "data-sort-dir" in attrs ? undefined : normalizedSortDir;
|
|
|
100
97
|
updateUI(key, nextDir);
|
|
101
98
|
root.dispatchEvent(new CustomEvent("av-sort", { bubbles: true, detail: { key, dir: nextDir } }));
|
|
102
99
|
|
|
103
|
-
if (control.tagName === "BUTTON") {
|
|
100
|
+
if (control.tagName === "BUTTON" || control.tagName === "A" || control.closest("a")) {
|
|
104
101
|
event.preventDefault();
|
|
105
102
|
}
|
|
106
103
|
});
|
|
107
104
|
});
|
|
108
105
|
})();
|
|
109
106
|
</script>
|
|
107
|
+
</div>
|
package/src/styles/global.css
CHANGED
|
@@ -1940,6 +1940,43 @@
|
|
|
1940
1940
|
background-size: 200% 100%;
|
|
1941
1941
|
}
|
|
1942
1942
|
|
|
1943
|
+
/* Loading overlay utility */
|
|
1944
|
+
.av-loading-overlay {
|
|
1945
|
+
position: fixed;
|
|
1946
|
+
inset: 0;
|
|
1947
|
+
background: rgba(15, 23, 42, 0.55);
|
|
1948
|
+
display: flex;
|
|
1949
|
+
align-items: center;
|
|
1950
|
+
justify-content: center;
|
|
1951
|
+
z-index: 950;
|
|
1952
|
+
}
|
|
1953
|
+
|
|
1954
|
+
.av-loading-panel {
|
|
1955
|
+
display: flex;
|
|
1956
|
+
align-items: center;
|
|
1957
|
+
gap: 0.75rem;
|
|
1958
|
+
padding: 0.85rem 1.1rem;
|
|
1959
|
+
border-radius: 999px;
|
|
1960
|
+
border: 1px solid var(--av-border-subtle);
|
|
1961
|
+
background: var(--av-surface);
|
|
1962
|
+
box-shadow: var(--av-shadow-soft);
|
|
1963
|
+
}
|
|
1964
|
+
|
|
1965
|
+
.av-loading-spinner {
|
|
1966
|
+
width: 18px;
|
|
1967
|
+
height: 18px;
|
|
1968
|
+
border-radius: 50%;
|
|
1969
|
+
border: 2px solid rgba(148, 163, 184, 0.35);
|
|
1970
|
+
border-top-color: var(--av-text);
|
|
1971
|
+
animation: av-spin 0.9s linear infinite;
|
|
1972
|
+
}
|
|
1973
|
+
|
|
1974
|
+
@keyframes av-spin {
|
|
1975
|
+
to {
|
|
1976
|
+
transform: rotate(360deg);
|
|
1977
|
+
}
|
|
1978
|
+
}
|
|
1979
|
+
|
|
1943
1980
|
/* Accordion */
|
|
1944
1981
|
.av-accordion {
|
|
1945
1982
|
border: 1px solid var(--av-border-subtle);
|