@kayord/ui 1.1.0 → 1.1.2

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.
@@ -1,4 +1,8 @@
1
- export declare const sum: <T>(data: T[], columnId: keyof T) => number;
2
- export declare const min: <T>(data: T[], columnId: keyof T) => number | undefined;
3
- export declare const max: <T>(data: T[], columnId: keyof T) => number | undefined;
4
- export declare const uniqueCount: <T>(data: T[], columnId: keyof T) => number;
1
+ export declare const aggregationFns: {
2
+ sum: <T>(data: T[], columnId: keyof T) => number;
3
+ min: <T>(data: T[], columnId: keyof T) => number | undefined;
4
+ max: <T>(data: T[], columnId: keyof T) => number | undefined;
5
+ mean: <T>(data: T[], columnId: keyof T) => number | undefined;
6
+ uniqueCount: <T>(data: T[], columnId: keyof T) => number;
7
+ count: <T>(data: T[], columnId: keyof T) => number;
8
+ };
@@ -1,10 +1,10 @@
1
- export const sum = (data, columnId) => {
1
+ const sum = (data, columnId) => {
2
2
  return data.reduce((sum, next) => {
3
3
  const nextValue = next[columnId];
4
4
  return sum + (typeof nextValue === "number" ? nextValue : 0);
5
5
  }, 0);
6
6
  };
7
- export const min = (data, columnId) => {
7
+ const min = (data, columnId) => {
8
8
  let min;
9
9
  data.forEach((row) => {
10
10
  const value = Number(row[columnId]);
@@ -14,7 +14,7 @@ export const min = (data, columnId) => {
14
14
  });
15
15
  return min;
16
16
  };
17
- export const max = (data, columnId) => {
17
+ const max = (data, columnId) => {
18
18
  let max;
19
19
  data.forEach((row) => {
20
20
  const value = Number(row[columnId]);
@@ -24,6 +24,30 @@ export const max = (data, columnId) => {
24
24
  });
25
25
  return max;
26
26
  };
27
- export const uniqueCount = (data, columnId) => {
27
+ const uniqueCount = (data, columnId) => {
28
28
  return new Set(data.map((d) => d[columnId])).size;
29
29
  };
30
+ const count = (data, columnId) => {
31
+ return data.length;
32
+ };
33
+ const mean = (data, columnId) => {
34
+ let count = 0;
35
+ let sum = 0;
36
+ data.forEach((row) => {
37
+ let value = Number(row[columnId]);
38
+ if (value != null && (value = +value) >= value) {
39
+ (++count, (sum += value));
40
+ }
41
+ });
42
+ if (count)
43
+ return sum / count;
44
+ return;
45
+ };
46
+ export const aggregationFns = {
47
+ sum,
48
+ min,
49
+ max,
50
+ mean,
51
+ uniqueCount,
52
+ count,
53
+ };
@@ -1,5 +1,5 @@
1
1
  export { default as DataTable } from "./DataTable.svelte";
2
2
  export { createShadTable } from "./shad-table.svelte";
3
- export { max, min, sum, uniqueCount } from "./data-table-utils";
3
+ export { aggregationFns } from "./data-table-utils";
4
4
  export { decodeColumnFilters, decodeGlobalFilter, decodePageIndex, decodeSorting, decodeTableState, encodeColumnFilters, encodeGlobalFilter, encodePageIndex, encodeSorting, encodeTableState, } from "./table-search-params";
5
5
  export type { CustomColumnMeta, CustomOptions } from "./types";
@@ -1,4 +1,4 @@
1
1
  export { default as DataTable } from "./DataTable.svelte";
2
2
  export { createShadTable } from "./shad-table.svelte";
3
- export { max, min, sum, uniqueCount } from "./data-table-utils";
3
+ export { aggregationFns } from "./data-table-utils";
4
4
  export { decodeColumnFilters, decodeGlobalFilter, decodePageIndex, decodeSorting, decodeTableState, encodeColumnFilters, encodeGlobalFilter, encodePageIndex, encodeSorting, encodeTableState, } from "./table-search-params";
@@ -1,5 +1,5 @@
1
1
  <script lang="ts">
2
- import { Sun, Moon } from "@lucide/svelte";
2
+ import { SunIcon, MoonIcon } from "@lucide/svelte";
3
3
  import { toggleMode } from "mode-watcher";
4
4
  import { Button } from "../../ui/button/index.js";
5
5
 
@@ -11,7 +11,7 @@
11
11
  </script>
12
12
 
13
13
  <Button onclick={toggleMode} {variant} size="icon">
14
- <Sun class="h-[1.2rem] w-[1.2rem] scale-100 rotate-0 transition-all dark:scale-0 dark:-rotate-90" />
15
- <Moon class="absolute h-[1.2rem] w-[1.2rem] scale-0 rotate-90 transition-all dark:scale-100 dark:rotate-0" />
14
+ <SunIcon class="scale-100 rotate-0 !transition-all dark:scale-0 dark:-rotate-90" />
15
+ <MoonIcon class="absolute scale-0 rotate-90 !transition-all dark:scale-100 dark:rotate-0" />
16
16
  <span class="sr-only">Toggle theme</span>
17
17
  </Button>
@@ -1,5 +1,5 @@
1
1
  <script lang="ts">
2
- import { Sun, Moon } from "@lucide/svelte";
2
+ import { SunIcon, MoonIcon } from "@lucide/svelte";
3
3
  import { resetMode, setMode } from "mode-watcher";
4
4
  import * as DropdownMenu from "../../ui/dropdown-menu/index.js";
5
5
  import { buttonVariants } from "../../ui/button/index.js";
@@ -13,8 +13,8 @@
13
13
 
14
14
  <DropdownMenu.Root>
15
15
  <DropdownMenu.Trigger class={buttonVariants({ variant, size: "icon" })}>
16
- <Sun class="h-[1.2rem] w-[1.2rem] scale-100 rotate-0 transition-all dark:scale-0 dark:-rotate-90" />
17
- <Moon class="absolute h-[1.2rem] w-[1.2rem] scale-0 rotate-90 transition-all dark:scale-100 dark:rotate-0" />
16
+ <SunIcon class="scale-100 rotate-0 !transition-all dark:scale-0 dark:-rotate-90" />
17
+ <MoonIcon class="absolute scale-0 rotate-90 !transition-all dark:scale-100 dark:rotate-0" />
18
18
  <span class="sr-only">Toggle theme</span>
19
19
  </DropdownMenu.Trigger>
20
20
  <DropdownMenu.Content align="end">
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@kayord/ui",
3
3
  "private": false,
4
- "version": "1.1.0",
4
+ "version": "1.1.2",
5
5
  "exports": {
6
6
  ".": {
7
7
  "types": "./dist/index.d.ts",
@@ -49,7 +49,7 @@
49
49
  "devDependencies": {
50
50
  "@lucide/svelte": "^0.525.0",
51
51
  "@sveltejs/adapter-auto": "^6.0.1",
52
- "@sveltejs/kit": "^2.24.0",
52
+ "@sveltejs/kit": "^2.25.1",
53
53
  "@sveltejs/package": "^2.4.0",
54
54
  "@sveltejs/vite-plugin-svelte": "^6.1.0",
55
55
  "@tailwindcss/vite": "^4.1.11",
@@ -63,7 +63,7 @@
63
63
  "d3-scale": "^4.0.2",
64
64
  "d3-shape": "^3.2.0",
65
65
  "eslint": "^9.31.0",
66
- "eslint-config-prettier": "^10.1.5",
66
+ "eslint-config-prettier": "^10.1.8",
67
67
  "eslint-plugin-svelte": "^3.11.0",
68
68
  "happy-dom": "^18.0.1",
69
69
  "layerchart": "2.0.0-next.30",
@@ -71,14 +71,14 @@
71
71
  "prettier-plugin-svelte": "^3.4.0",
72
72
  "prettier-plugin-tailwindcss": "^0.6.14",
73
73
  "publint": "^0.3.12",
74
- "svelte": "5.36.4",
75
- "svelte-check": "^4.2.2",
74
+ "svelte": "5.36.10",
75
+ "svelte-check": "^4.3.0",
76
76
  "sveltekit-superforms": "^2.27.1",
77
77
  "tailwindcss": "^4.1.11",
78
78
  "tslib": "^2.8.1",
79
79
  "tw-animate-css": "1.3.5",
80
80
  "typescript": "^5.8.3",
81
- "vite": "^7.0.4",
81
+ "vite": "^7.0.5",
82
82
  "vitest": "^3.2.4",
83
83
  "zod": "^4.0.5"
84
84
  },