@steez-ui/ui 0.1.2 → 0.1.4

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.
Files changed (47) hide show
  1. package/README.md +8 -5
  2. package/dist/components/AvatarStage.d.ts +10 -0
  3. package/dist/components/AvatarStage.d.ts.map +1 -0
  4. package/dist/components/AvatarStage.js +11 -0
  5. package/dist/components/AvatarStage.js.map +1 -0
  6. package/dist/components/AvatarStage.module.css +34 -0
  7. package/dist/components/BlinkText.d.ts +13 -0
  8. package/dist/components/BlinkText.d.ts.map +1 -0
  9. package/dist/components/BlinkText.js +13 -0
  10. package/dist/components/BlinkText.js.map +1 -0
  11. package/dist/components/BlinkText.module.css +40 -0
  12. package/dist/components/CyberpunkCheckbox.js +1 -1
  13. package/dist/components/CyberpunkCheckbox.js.map +1 -1
  14. package/dist/components/CyberpunkInput.js +1 -1
  15. package/dist/components/CyberpunkInput.js.map +1 -1
  16. package/dist/components/CyberpunkRadio.js +1 -1
  17. package/dist/components/CyberpunkRadio.js.map +1 -1
  18. package/dist/components/CyberpunkSelect.js +1 -1
  19. package/dist/components/CyberpunkSelect.js.map +1 -1
  20. package/dist/components/CyberpunkSlider.js +1 -1
  21. package/dist/components/CyberpunkSlider.js.map +1 -1
  22. package/dist/components/CyberpunkTextarea.js +1 -1
  23. package/dist/components/CyberpunkTextarea.js.map +1 -1
  24. package/dist/components/HeartbeatPulse.d.ts +19 -0
  25. package/dist/components/HeartbeatPulse.d.ts.map +1 -0
  26. package/dist/components/HeartbeatPulse.js +33 -0
  27. package/dist/components/HeartbeatPulse.js.map +1 -0
  28. package/dist/components/HeartbeatPulse.module.css +34 -0
  29. package/dist/components/MarqueeStrip.d.ts +13 -0
  30. package/dist/components/MarqueeStrip.d.ts.map +1 -0
  31. package/dist/components/MarqueeStrip.js +12 -0
  32. package/dist/components/MarqueeStrip.js.map +1 -0
  33. package/dist/components/MarqueeStrip.module.css +36 -0
  34. package/dist/components/PageTemplate.d.ts +1 -1
  35. package/dist/components/PageTemplate.d.ts.map +1 -1
  36. package/dist/components/PageTemplate.js +1 -1
  37. package/dist/components/PageTemplate.js.map +1 -1
  38. package/dist/components/StrokedText.d.ts +10 -0
  39. package/dist/components/StrokedText.d.ts.map +1 -0
  40. package/dist/components/StrokedText.js +12 -0
  41. package/dist/components/StrokedText.js.map +1 -0
  42. package/dist/components/StrokedText.module.css +63 -0
  43. package/dist/index.d.ts +24 -19
  44. package/dist/index.d.ts.map +1 -1
  45. package/dist/index.js +24 -19
  46. package/dist/index.js.map +1 -1
  47. package/package.json +3 -3
package/README.md CHANGED
@@ -15,6 +15,7 @@ Live surfaces:
15
15
 
16
16
  - Registry frontend: `https://steez-ui-6v5.pages.dev`
17
17
  - Docs: `https://steez-ui-6v5.pages.dev/docs/`
18
+ - Components: `https://steez-ui-6v5.pages.dev/components/`
18
19
  - Packages: `https://steez-ui-6v5.pages.dev/packages/`
19
20
  - Registry page: `https://steez-ui-6v5.pages.dev/registry/`
20
21
  - Registry index: `https://steez-ui-6v5.pages.dev/r/index.json`
@@ -75,6 +76,7 @@ bun run test:install-smoke
75
76
  Useful commands:
76
77
 
77
78
  - `bun run generate:registry`
79
+ - `bun run generate:component-pages`
78
80
  - `bun run check:release`
79
81
  - `bun run publish:packages:dry-run`
80
82
  - `bun run publish:packages`
@@ -85,8 +87,9 @@ Useful commands:
85
87
  1. Build or update the component in `packages/ui/src/components`.
86
88
  2. Export it from `packages/ui/src/index.ts`.
87
89
  3. Add or update the registry item definition in `scripts/generate-registry.mjs`.
88
- 4. Run `bun run build` and `bun run test`.
89
- 5. Confirm the registry frontend reflects the new component or install path.
90
+ 4. Add or update the docs metadata and preview in `apps/registry/src/components-docs/`.
91
+ 5. Run `bun run build` and `bun run test`.
92
+ 6. Confirm the registry frontend reflects the new component or install path.
90
93
 
91
94
  ## Release Flow
92
95
 
@@ -98,9 +101,9 @@ GitHub Actions mirror the same CI, npm publish, and Cloudflare Pages deploy path
98
101
 
99
102
  ## Current Packages
100
103
 
101
- - `@steez-ui/theme@0.1.2`
102
- - `@steez-ui/icons@0.1.2`
103
- - `@steez-ui/ui@0.1.2`
104
+ - `@steez-ui/theme@0.1.4`
105
+ - `@steez-ui/icons@0.1.4`
106
+ - `@steez-ui/ui@0.1.4`
104
107
 
105
108
  ## External Setup
106
109
 
@@ -0,0 +1,10 @@
1
+ import React from "react";
2
+ export interface AvatarStageProps extends React.HTMLAttributes<HTMLDivElement> {
3
+ children: React.ReactNode;
4
+ backdrop?: React.ReactNode;
5
+ stageHeight?: number | string;
6
+ viewportWidth?: number | string;
7
+ viewportClassName?: string;
8
+ }
9
+ export declare function AvatarStage({ children, backdrop, stageHeight, viewportWidth, className, viewportClassName, style, ...props }: AvatarStageProps): import("react/jsx-runtime").JSX.Element;
10
+ //# sourceMappingURL=AvatarStage.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AvatarStage.d.ts","sourceRoot":"","sources":["../../src/components/AvatarStage.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,MAAM,WAAW,gBAAiB,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IAC5E,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC3B,WAAW,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAC9B,aAAa,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAChC,iBAAiB,CAAC,EAAE,MAAM,CAAC;CAC5B;AAED,wBAAgB,WAAW,CAAC,EAC1B,QAAQ,EACR,QAAQ,EACR,WAAqB,EACrB,aAAkC,EAClC,SAAc,EACd,iBAAsB,EACtB,KAAK,EACL,GAAG,KAAK,EACT,EAAE,gBAAgB,2CAelB"}
@@ -0,0 +1,11 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import styles from "./AvatarStage.module.css";
3
+ export function AvatarStage({ children, backdrop, stageHeight = "34rem", viewportWidth = "min(100%, 30rem)", className = "", viewportClassName = "", style, ...props }) {
4
+ const mergedStyle = {
5
+ ...style,
6
+ ["--avatar-stage-height"]: typeof stageHeight === "number" ? `${stageHeight}px` : stageHeight,
7
+ ["--avatar-stage-viewport-width"]: typeof viewportWidth === "number" ? `${viewportWidth}px` : viewportWidth,
8
+ };
9
+ return (_jsxs("div", { className: `${styles.root} ${className}`.trim(), style: mergedStyle, ...props, children: [backdrop ? _jsx("div", { className: styles.backdrop, children: backdrop }) : null, _jsx("div", { className: `${styles.viewport} ${viewportClassName}`.trim(), children: children })] }));
10
+ }
11
+ //# sourceMappingURL=AvatarStage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AvatarStage.js","sourceRoot":"","sources":["../../src/components/AvatarStage.tsx"],"names":[],"mappings":";AAEA,OAAO,MAAM,MAAM,0BAA0B,CAAC;AAU9C,MAAM,UAAU,WAAW,CAAC,EAC1B,QAAQ,EACR,QAAQ,EACR,WAAW,GAAG,OAAO,EACrB,aAAa,GAAG,kBAAkB,EAClC,SAAS,GAAG,EAAE,EACd,iBAAiB,GAAG,EAAE,EACtB,KAAK,EACL,GAAG,KAAK,EACS;IACjB,MAAM,WAAW,GAAG;QAClB,GAAG,KAAK;QACR,CAAC,uBAAiC,CAAC,EACjC,OAAO,WAAW,KAAK,QAAQ,CAAC,CAAC,CAAC,GAAG,WAAW,IAAI,CAAC,CAAC,CAAC,WAAW;QACpE,CAAC,+BAAyC,CAAC,EACzC,OAAO,aAAa,KAAK,QAAQ,CAAC,CAAC,CAAC,GAAG,aAAa,IAAI,CAAC,CAAC,CAAC,aAAa;KACpD,CAAC;IAEzB,OAAO,CACL,eAAK,SAAS,EAAE,GAAG,MAAM,CAAC,IAAI,IAAI,SAAS,EAAE,CAAC,IAAI,EAAE,EAAE,KAAK,EAAE,WAAW,KAAM,KAAK,aAChF,QAAQ,CAAC,CAAC,CAAC,cAAK,SAAS,EAAE,MAAM,CAAC,QAAQ,YAAG,QAAQ,GAAO,CAAC,CAAC,CAAC,IAAI,EACpE,cAAK,SAAS,EAAE,GAAG,MAAM,CAAC,QAAQ,IAAI,iBAAiB,EAAE,CAAC,IAAI,EAAE,YAAG,QAAQ,GAAO,IAC9E,CACP,CAAC;AACJ,CAAC"}
@@ -0,0 +1,34 @@
1
+ .root {
2
+ position: relative;
3
+ display: grid;
4
+ align-items: end;
5
+ justify-items: center;
6
+ min-height: var(--avatar-stage-height, 34rem);
7
+ overflow: hidden;
8
+ isolation: isolate;
9
+ }
10
+
11
+ .root::after {
12
+ content: "";
13
+ position: absolute;
14
+ inset-inline: 0;
15
+ bottom: 0;
16
+ z-index: 2;
17
+ border-bottom: 1px solid color-mix(in srgb, var(--border-color) 78%, transparent);
18
+ pointer-events: none;
19
+ }
20
+
21
+ .backdrop {
22
+ position: absolute;
23
+ inset: 0;
24
+ z-index: 0;
25
+ }
26
+
27
+ .viewport {
28
+ position: relative;
29
+ z-index: 1;
30
+ width: var(--avatar-stage-viewport-width, min(100%, 30rem));
31
+ max-width: 100%;
32
+ height: 100%;
33
+ min-height: var(--avatar-stage-height, 34rem);
34
+ }
@@ -0,0 +1,13 @@
1
+ import React from "react";
2
+ type BlinkTrigger = "mount" | "hover" | "always";
3
+ export interface BlinkTextProps extends React.HTMLAttributes<HTMLSpanElement> {
4
+ children: React.ReactNode;
5
+ trigger?: BlinkTrigger;
6
+ durationMs?: number;
7
+ iterations?: number | "infinite";
8
+ delayMs?: number;
9
+ dimOpacity?: number;
10
+ }
11
+ export declare function BlinkText({ children, trigger, durationMs, iterations, delayMs, dimOpacity, className, style, ...props }: BlinkTextProps): import("react/jsx-runtime").JSX.Element;
12
+ export {};
13
+ //# sourceMappingURL=BlinkText.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BlinkText.d.ts","sourceRoot":"","sources":["../../src/components/BlinkText.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,KAAK,YAAY,GAAG,OAAO,GAAG,OAAO,GAAG,QAAQ,CAAC;AAEjD,MAAM,WAAW,cAAe,SAAQ,KAAK,CAAC,cAAc,CAAC,eAAe,CAAC;IAC3E,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,OAAO,CAAC,EAAE,YAAY,CAAC;IACvB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,UAAU,CAAC,EAAE,MAAM,GAAG,UAAU,CAAC;IACjC,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED,wBAAgB,SAAS,CAAC,EACxB,QAAQ,EACR,OAAiB,EACjB,UAAgB,EAChB,UAAc,EACd,OAAW,EACX,UAAiB,EACjB,SAAc,EACd,KAAK,EACL,GAAG,KAAK,EACT,EAAE,cAAc,2CAmBhB"}
@@ -0,0 +1,13 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import styles from "./BlinkText.module.css";
3
+ export function BlinkText({ children, trigger = "hover", durationMs = 420, iterations = 3, delayMs = 0, dimOpacity = 0.12, className = "", style, ...props }) {
4
+ const mergedStyle = {
5
+ ...style,
6
+ ["--blink-duration"]: `${durationMs}ms`,
7
+ ["--blink-iterations"]: iterations === "infinite" ? "infinite" : String(iterations),
8
+ ["--blink-delay"]: `${delayMs}ms`,
9
+ ["--blink-dim-opacity"]: String(dimOpacity),
10
+ };
11
+ return (_jsx("span", { className: `${styles.root} ${styles[trigger]} ${className}`.trim(), style: mergedStyle, ...props, children: children }));
12
+ }
13
+ //# sourceMappingURL=BlinkText.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BlinkText.js","sourceRoot":"","sources":["../../src/components/BlinkText.tsx"],"names":[],"mappings":";AAEA,OAAO,MAAM,MAAM,wBAAwB,CAAC;AAa5C,MAAM,UAAU,SAAS,CAAC,EACxB,QAAQ,EACR,OAAO,GAAG,OAAO,EACjB,UAAU,GAAG,GAAG,EAChB,UAAU,GAAG,CAAC,EACd,OAAO,GAAG,CAAC,EACX,UAAU,GAAG,IAAI,EACjB,SAAS,GAAG,EAAE,EACd,KAAK,EACL,GAAG,KAAK,EACO;IACf,MAAM,WAAW,GAAG;QAClB,GAAG,KAAK;QACR,CAAC,kBAA4B,CAAC,EAAE,GAAG,UAAU,IAAI;QACjD,CAAC,oBAA8B,CAAC,EAC9B,UAAU,KAAK,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC;QAC7D,CAAC,eAAyB,CAAC,EAAE,GAAG,OAAO,IAAI;QAC3C,CAAC,qBAA+B,CAAC,EAAE,MAAM,CAAC,UAAU,CAAC;KAC/B,CAAC;IAEzB,OAAO,CACL,eACE,SAAS,EAAE,GAAG,MAAM,CAAC,IAAI,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,SAAS,EAAE,CAAC,IAAI,EAAE,EAClE,KAAK,EAAE,WAAW,KACd,KAAK,YAER,QAAQ,GACJ,CACR,CAAC;AACJ,CAAC"}
@@ -0,0 +1,40 @@
1
+ .root {
2
+ display: inline-flex;
3
+ align-items: center;
4
+ }
5
+
6
+ .mount {
7
+ animation: blinkText var(--blink-duration, 420ms) steps(2, end)
8
+ var(--blink-delay, 0ms) var(--blink-iterations, 3);
9
+ }
10
+
11
+ .always {
12
+ animation: blinkText var(--blink-duration, 420ms) steps(2, end)
13
+ var(--blink-delay, 0ms) infinite;
14
+ }
15
+
16
+ .hover:hover {
17
+ animation: blinkText var(--blink-duration, 420ms) steps(2, end)
18
+ var(--blink-delay, 0ms) var(--blink-iterations, 3);
19
+ }
20
+
21
+ @keyframes blinkText {
22
+ 0%,
23
+ 100% {
24
+ opacity: 1;
25
+ }
26
+
27
+ 20%,
28
+ 40%,
29
+ 60%,
30
+ 80% {
31
+ opacity: var(--blink-dim-opacity, 0.12);
32
+ }
33
+
34
+ 30%,
35
+ 50%,
36
+ 70%,
37
+ 90% {
38
+ opacity: 1;
39
+ }
40
+ }
@@ -1,5 +1,5 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { useStableId } from "../hooks/useStableId";
2
+ import { useStableId } from "../hooks/useStableId.js";
3
3
  import styles from "./CyberpunkCheckbox.module.css";
4
4
  export function CyberpunkCheckbox({ label, className = "", id, onChange, ...props }) {
5
5
  const inputId = useStableId("checkbox", id);
@@ -1 +1 @@
1
- {"version":3,"file":"CyberpunkCheckbox.js","sourceRoot":"","sources":["../../src/components/CyberpunkCheckbox.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,MAAM,MAAM,gCAAgC,CAAC;AAQpD,MAAM,UAAU,iBAAiB,CAAC,EAChC,KAAK,EACL,SAAS,GAAG,EAAE,EACd,EAAE,EACF,QAAQ,EACR,GAAG,KAAK,EACe;IACvB,MAAM,OAAO,GAAG,WAAW,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;IAE5C,OAAO,CACL,iBAAO,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC,OAAO,IAAI,SAAS,EAAE,CAAC,IAAI,EAAE,aACzE,gBACE,EAAE,EAAE,OAAO,EACX,IAAI,EAAC,UAAU,EACf,SAAS,EAAE,MAAM,CAAC,QAAQ,EAC1B,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,QAAQ,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,KACjD,KAAK,GACT,EACD,KAAK,CAAC,CAAC,CAAC,eAAM,SAAS,EAAE,MAAM,CAAC,KAAK,YAAG,KAAK,GAAQ,CAAC,CAAC,CAAC,IAAI,IACvD,CACT,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"CyberpunkCheckbox.js","sourceRoot":"","sources":["../../src/components/CyberpunkCheckbox.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AACtD,OAAO,MAAM,MAAM,gCAAgC,CAAC;AAQpD,MAAM,UAAU,iBAAiB,CAAC,EAChC,KAAK,EACL,SAAS,GAAG,EAAE,EACd,EAAE,EACF,QAAQ,EACR,GAAG,KAAK,EACe;IACvB,MAAM,OAAO,GAAG,WAAW,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;IAE5C,OAAO,CACL,iBAAO,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC,OAAO,IAAI,SAAS,EAAE,CAAC,IAAI,EAAE,aACzE,gBACE,EAAE,EAAE,OAAO,EACX,IAAI,EAAC,UAAU,EACf,SAAS,EAAE,MAAM,CAAC,QAAQ,EAC1B,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,QAAQ,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,KACjD,KAAK,GACT,EACD,KAAK,CAAC,CAAC,CAAC,eAAM,SAAS,EAAE,MAAM,CAAC,KAAK,YAAG,KAAK,GAAQ,CAAC,CAAC,CAAC,IAAI,IACvD,CACT,CAAC;AACJ,CAAC"}
@@ -1,5 +1,5 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { useStableId } from "../hooks/useStableId";
2
+ import { useStableId } from "../hooks/useStableId.js";
3
3
  import styles from "./CyberpunkInput.module.css";
4
4
  export function CyberpunkInput({ label, variant = "default", className = "", id, disabled, readOnly, helperText, icon, ...props }) {
5
5
  const inputId = useStableId("input", id);
@@ -1 +1 @@
1
- {"version":3,"file":"CyberpunkInput.js","sourceRoot":"","sources":["../../src/components/CyberpunkInput.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,MAAM,MAAM,6BAA6B,CAAC;AAUjD,MAAM,UAAU,cAAc,CAAC,EAC7B,KAAK,EACL,OAAO,GAAG,SAAS,EACnB,SAAS,GAAG,EAAE,EACd,EAAE,EACF,QAAQ,EACR,QAAQ,EACR,UAAU,EACV,IAAI,EACJ,GAAG,KAAK,EACY;IACpB,MAAM,OAAO,GAAG,WAAW,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;IACzC,MAAM,oBAAoB,GAAG,QAAQ,IAAI,QAAQ,CAAC;IAElD,OAAO,CACL,eAAK,SAAS,EAAE,GAAG,MAAM,CAAC,UAAU,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,SAAS,EAAE,CAAC,IAAI,EAAE,aAC1E,KAAK,CAAC,CAAC,CAAC,CACP,gBAAO,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,CAAC,KAAK,YAC7C,KAAK,GACA,CACT,CAAC,CAAC,CAAC,IAAI,EACR,eACE,SAAS,EAAE,GAAG,MAAM,CAAC,cAAc,IAAI,oBAAoB,CAAC,CAAC,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE,IAAI,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,EAAE,aAElI,IAAI,CAAC,CAAC,CAAC,cAAK,SAAS,EAAE,MAAM,CAAC,IAAI,YAAG,IAAI,GAAO,CAAC,CAAC,CAAC,IAAI,EACxD,gBAAO,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,CAAC,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,KAAM,KAAK,GAAI,IAC9F,EACL,UAAU,CAAC,CAAC,CAAC,cAAK,SAAS,EAAE,MAAM,CAAC,UAAU,YAAG,UAAU,GAAO,CAAC,CAAC,CAAC,IAAI,IACtE,CACP,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"CyberpunkInput.js","sourceRoot":"","sources":["../../src/components/CyberpunkInput.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AACtD,OAAO,MAAM,MAAM,6BAA6B,CAAC;AAUjD,MAAM,UAAU,cAAc,CAAC,EAC7B,KAAK,EACL,OAAO,GAAG,SAAS,EACnB,SAAS,GAAG,EAAE,EACd,EAAE,EACF,QAAQ,EACR,QAAQ,EACR,UAAU,EACV,IAAI,EACJ,GAAG,KAAK,EACY;IACpB,MAAM,OAAO,GAAG,WAAW,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;IACzC,MAAM,oBAAoB,GAAG,QAAQ,IAAI,QAAQ,CAAC;IAElD,OAAO,CACL,eAAK,SAAS,EAAE,GAAG,MAAM,CAAC,UAAU,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,SAAS,EAAE,CAAC,IAAI,EAAE,aAC1E,KAAK,CAAC,CAAC,CAAC,CACP,gBAAO,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,CAAC,KAAK,YAC7C,KAAK,GACA,CACT,CAAC,CAAC,CAAC,IAAI,EACR,eACE,SAAS,EAAE,GAAG,MAAM,CAAC,cAAc,IAAI,oBAAoB,CAAC,CAAC,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC,CAAC,EAAE,IAAI,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,EAAE,aAElI,IAAI,CAAC,CAAC,CAAC,cAAK,SAAS,EAAE,MAAM,CAAC,IAAI,YAAG,IAAI,GAAO,CAAC,CAAC,CAAC,IAAI,EACxD,gBAAO,EAAE,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,CAAC,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,KAAM,KAAK,GAAI,IAC9F,EACL,UAAU,CAAC,CAAC,CAAC,cAAK,SAAS,EAAE,MAAM,CAAC,UAAU,YAAG,UAAU,GAAO,CAAC,CAAC,CAAC,IAAI,IACtE,CACP,CAAC;AACJ,CAAC"}
@@ -1,5 +1,5 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { useStableId } from "../hooks/useStableId";
2
+ import { useStableId } from "../hooks/useStableId.js";
3
3
  import styles from "./CyberpunkRadio.module.css";
4
4
  export function CyberpunkRadio({ label, className = "", id, ...props }) {
5
5
  const inputId = useStableId("radio", id);
@@ -1 +1 @@
1
- {"version":3,"file":"CyberpunkRadio.js","sourceRoot":"","sources":["../../src/components/CyberpunkRadio.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,MAAM,MAAM,6BAA6B,CAAC;AAMjD,MAAM,UAAU,cAAc,CAAC,EAAE,KAAK,EAAE,SAAS,GAAG,EAAE,EAAE,EAAE,EAAE,GAAG,KAAK,EAAuB;IACzF,MAAM,OAAO,GAAG,WAAW,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;IAEzC,OAAO,CACL,iBAAO,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC,OAAO,IAAI,SAAS,EAAE,CAAC,IAAI,EAAE,aACzE,gBAAO,EAAE,EAAE,OAAO,EAAE,IAAI,EAAC,OAAO,EAAC,SAAS,EAAE,MAAM,CAAC,KAAK,KAAM,KAAK,GAAI,EACtE,KAAK,CAAC,CAAC,CAAC,eAAM,SAAS,EAAE,MAAM,CAAC,KAAK,YAAG,KAAK,GAAQ,CAAC,CAAC,CAAC,IAAI,IACvD,CACT,CAAC;AACJ,CAAC;AAUD,MAAM,UAAU,mBAAmB,CAAC,EAClC,IAAI,EACJ,OAAO,EACP,KAAK,EACL,QAAQ,EACR,SAAS,GAAG,EAAE,GACW;IACzB,OAAO,CACL,cAAK,SAAS,EAAE,GAAG,MAAM,CAAC,UAAU,IAAI,SAAS,EAAE,CAAC,IAAI,EAAE,YACvD,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CACvB,KAAC,cAAc,IAEb,IAAI,EAAE,IAAI,EACV,KAAK,EAAE,MAAM,CAAC,KAAK,EACnB,KAAK,EAAE,MAAM,CAAC,KAAK,EACnB,OAAO,EAAE,KAAK,KAAK,MAAM,CAAC,KAAK,EAC/B,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,QAAQ,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,IAL9C,MAAM,CAAC,KAAK,CAMjB,CACH,CAAC,GACE,CACP,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"CyberpunkRadio.js","sourceRoot":"","sources":["../../src/components/CyberpunkRadio.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AACtD,OAAO,MAAM,MAAM,6BAA6B,CAAC;AAMjD,MAAM,UAAU,cAAc,CAAC,EAAE,KAAK,EAAE,SAAS,GAAG,EAAE,EAAE,EAAE,EAAE,GAAG,KAAK,EAAuB;IACzF,MAAM,OAAO,GAAG,WAAW,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC;IAEzC,OAAO,CACL,iBAAO,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC,OAAO,IAAI,SAAS,EAAE,CAAC,IAAI,EAAE,aACzE,gBAAO,EAAE,EAAE,OAAO,EAAE,IAAI,EAAC,OAAO,EAAC,SAAS,EAAE,MAAM,CAAC,KAAK,KAAM,KAAK,GAAI,EACtE,KAAK,CAAC,CAAC,CAAC,eAAM,SAAS,EAAE,MAAM,CAAC,KAAK,YAAG,KAAK,GAAQ,CAAC,CAAC,CAAC,IAAI,IACvD,CACT,CAAC;AACJ,CAAC;AAUD,MAAM,UAAU,mBAAmB,CAAC,EAClC,IAAI,EACJ,OAAO,EACP,KAAK,EACL,QAAQ,EACR,SAAS,GAAG,EAAE,GACW;IACzB,OAAO,CACL,cAAK,SAAS,EAAE,GAAG,MAAM,CAAC,UAAU,IAAI,SAAS,EAAE,CAAC,IAAI,EAAE,YACvD,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CACvB,KAAC,cAAc,IAEb,IAAI,EAAE,IAAI,EACV,KAAK,EAAE,MAAM,CAAC,KAAK,EACnB,KAAK,EAAE,MAAM,CAAC,KAAK,EACnB,OAAO,EAAE,KAAK,KAAK,MAAM,CAAC,KAAK,EAC/B,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,QAAQ,EAAE,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,IAL9C,MAAM,CAAC,KAAK,CAMjB,CACH,CAAC,GACE,CACP,CAAC;AACJ,CAAC"}
@@ -1,5 +1,5 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { useStableId } from "../hooks/useStableId";
2
+ import { useStableId } from "../hooks/useStableId.js";
3
3
  import styles from "./CyberpunkSelect.module.css";
4
4
  export function CyberpunkSelect({ label, variant = "default", options = [], className = "", id, value, ...props }) {
5
5
  const selectId = useStableId("select", id);
@@ -1 +1 @@
1
- {"version":3,"file":"CyberpunkSelect.js","sourceRoot":"","sources":["../../src/components/CyberpunkSelect.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,MAAM,MAAM,8BAA8B,CAAC;AAalD,MAAM,UAAU,eAAe,CAAC,EAC9B,KAAK,EACL,OAAO,GAAG,SAAS,EACnB,OAAO,GAAG,EAAE,EACZ,SAAS,GAAG,EAAE,EACd,EAAE,EACF,KAAK,EACL,GAAG,KAAK,EACa;IACrB,MAAM,QAAQ,GAAG,WAAW,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;IAE3C,OAAO,CACL,eAAK,SAAS,EAAE,GAAG,MAAM,CAAC,WAAW,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,SAAS,EAAE,CAAC,IAAI,EAAE,aAC3E,KAAK,CAAC,CAAC,CAAC,CACP,gBAAO,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,CAAC,KAAK,YAC9C,KAAK,GACA,CACT,CAAC,CAAC,CAAC,IAAI,EACR,iBAAQ,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,KAAK,EAAE,KAAK,KAAM,KAAK,YACpE,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CACvB,iBAA2B,KAAK,EAAE,MAAM,CAAC,KAAK,YAC3C,MAAM,CAAC,KAAK,IADF,MAAM,CAAC,KAAK,CAEhB,CACV,CAAC,GACK,EACT,cAAK,SAAS,EAAE,MAAM,CAAC,KAAK,YAC1B,cAAK,KAAK,EAAC,IAAI,EAAC,MAAM,EAAC,GAAG,EAAC,OAAO,EAAC,UAAU,EAAC,IAAI,EAAC,MAAM,YACvD,eAAM,CAAC,EAAC,eAAe,EAAC,MAAM,EAAC,cAAc,EAAC,WAAW,EAAC,GAAG,EAAC,aAAa,EAAC,OAAO,GAAG,GAClF,GACF,IACF,CACP,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"CyberpunkSelect.js","sourceRoot":"","sources":["../../src/components/CyberpunkSelect.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AACtD,OAAO,MAAM,MAAM,8BAA8B,CAAC;AAalD,MAAM,UAAU,eAAe,CAAC,EAC9B,KAAK,EACL,OAAO,GAAG,SAAS,EACnB,OAAO,GAAG,EAAE,EACZ,SAAS,GAAG,EAAE,EACd,EAAE,EACF,KAAK,EACL,GAAG,KAAK,EACa;IACrB,MAAM,QAAQ,GAAG,WAAW,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;IAE3C,OAAO,CACL,eAAK,SAAS,EAAE,GAAG,MAAM,CAAC,WAAW,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,SAAS,EAAE,CAAC,IAAI,EAAE,aAC3E,KAAK,CAAC,CAAC,CAAC,CACP,gBAAO,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,CAAC,KAAK,YAC9C,KAAK,GACA,CACT,CAAC,CAAC,CAAC,IAAI,EACR,iBAAQ,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,KAAK,EAAE,KAAK,KAAM,KAAK,YACpE,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CACvB,iBAA2B,KAAK,EAAE,MAAM,CAAC,KAAK,YAC3C,MAAM,CAAC,KAAK,IADF,MAAM,CAAC,KAAK,CAEhB,CACV,CAAC,GACK,EACT,cAAK,SAAS,EAAE,MAAM,CAAC,KAAK,YAC1B,cAAK,KAAK,EAAC,IAAI,EAAC,MAAM,EAAC,GAAG,EAAC,OAAO,EAAC,UAAU,EAAC,IAAI,EAAC,MAAM,YACvD,eAAM,CAAC,EAAC,eAAe,EAAC,MAAM,EAAC,cAAc,EAAC,WAAW,EAAC,GAAG,EAAC,aAAa,EAAC,OAAO,GAAG,GAClF,GACF,IACF,CACP,CAAC;AACJ,CAAC"}
@@ -1,5 +1,5 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { useStableId } from "../hooks/useStableId";
2
+ import { useStableId } from "../hooks/useStableId.js";
3
3
  import styles from "./CyberpunkSlider.module.css";
4
4
  export function CyberpunkSlider({ label, className = "", id, min = 0, max = 100, step = 1, showValue = true, value = 0, ...props }) {
5
5
  const inputId = useStableId("slider", id);
@@ -1 +1 @@
1
- {"version":3,"file":"CyberpunkSlider.js","sourceRoot":"","sources":["../../src/components/CyberpunkSlider.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,MAAM,MAAM,8BAA8B,CAAC;AAWlD,MAAM,UAAU,eAAe,CAAC,EAC9B,KAAK,EACL,SAAS,GAAG,EAAE,EACd,EAAE,EACF,GAAG,GAAG,CAAC,EACP,GAAG,GAAG,GAAG,EACT,IAAI,GAAG,CAAC,EACR,SAAS,GAAG,IAAI,EAChB,KAAK,GAAG,CAAC,EACT,GAAG,KAAK,EACa;IACrB,MAAM,OAAO,GAAG,WAAW,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;IAC1C,MAAM,UAAU,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC;IAE/D,OAAO,CACL,eAAK,SAAS,EAAE,GAAG,MAAM,CAAC,OAAO,IAAI,SAAS,EAAE,CAAC,IAAI,EAAE,aACpD,KAAK,CAAC,CAAC,CAAC,CACP,gBAAO,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,CAAC,KAAK,YAC7C,KAAK,GACA,CACT,CAAC,CAAC,CAAC,IAAI,EACR,eAAK,SAAS,EAAE,MAAM,CAAC,eAAe,aACpC,gBACE,EAAE,EAAE,OAAO,EACX,IAAI,EAAC,OAAO,EACZ,GAAG,EAAE,GAAG,EACR,GAAG,EAAE,GAAG,EACR,IAAI,EAAE,IAAI,EACV,KAAK,EAAE,KAAK,EACZ,SAAS,EAAE,MAAM,CAAC,MAAM,EACxB,KAAK,EAAE,EAAE,CAAC,qBAA+B,CAAC,EAAE,GAAG,UAAU,GAAG,EAAyB,KACjF,KAAK,GACT,EACD,SAAS,CAAC,CAAC,CAAC,eAAM,SAAS,EAAE,MAAM,CAAC,KAAK,YAAG,KAAK,GAAQ,CAAC,CAAC,CAAC,IAAI,IAC7D,IACF,CACP,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"CyberpunkSlider.js","sourceRoot":"","sources":["../../src/components/CyberpunkSlider.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AACtD,OAAO,MAAM,MAAM,8BAA8B,CAAC;AAWlD,MAAM,UAAU,eAAe,CAAC,EAC9B,KAAK,EACL,SAAS,GAAG,EAAE,EACd,EAAE,EACF,GAAG,GAAG,CAAC,EACP,GAAG,GAAG,GAAG,EACT,IAAI,GAAG,CAAC,EACR,SAAS,GAAG,IAAI,EAChB,KAAK,GAAG,CAAC,EACT,GAAG,KAAK,EACa;IACrB,MAAM,OAAO,GAAG,WAAW,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;IAC1C,MAAM,UAAU,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC;IAE/D,OAAO,CACL,eAAK,SAAS,EAAE,GAAG,MAAM,CAAC,OAAO,IAAI,SAAS,EAAE,CAAC,IAAI,EAAE,aACpD,KAAK,CAAC,CAAC,CAAC,CACP,gBAAO,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,CAAC,KAAK,YAC7C,KAAK,GACA,CACT,CAAC,CAAC,CAAC,IAAI,EACR,eAAK,SAAS,EAAE,MAAM,CAAC,eAAe,aACpC,gBACE,EAAE,EAAE,OAAO,EACX,IAAI,EAAC,OAAO,EACZ,GAAG,EAAE,GAAG,EACR,GAAG,EAAE,GAAG,EACR,IAAI,EAAE,IAAI,EACV,KAAK,EAAE,KAAK,EACZ,SAAS,EAAE,MAAM,CAAC,MAAM,EACxB,KAAK,EAAE,EAAE,CAAC,qBAA+B,CAAC,EAAE,GAAG,UAAU,GAAG,EAAyB,KACjF,KAAK,GACT,EACD,SAAS,CAAC,CAAC,CAAC,eAAM,SAAS,EAAE,MAAM,CAAC,KAAK,YAAG,KAAK,GAAQ,CAAC,CAAC,CAAC,IAAI,IAC7D,IACF,CACP,CAAC;AACJ,CAAC"}
@@ -1,5 +1,5 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { useStableId } from "../hooks/useStableId";
2
+ import { useStableId } from "../hooks/useStableId.js";
3
3
  import styles from "./CyberpunkTextarea.module.css";
4
4
  export function CyberpunkTextarea({ label, variant = "default", className = "", id, ...props }) {
5
5
  const textareaId = useStableId("textarea", id);
@@ -1 +1 @@
1
- {"version":3,"file":"CyberpunkTextarea.js","sourceRoot":"","sources":["../../src/components/CyberpunkTextarea.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,MAAM,MAAM,gCAAgC,CAAC;AAOpD,MAAM,UAAU,iBAAiB,CAAC,EAChC,KAAK,EACL,OAAO,GAAG,SAAS,EACnB,SAAS,GAAG,EAAE,EACd,EAAE,EACF,GAAG,KAAK,EACe;IACvB,MAAM,UAAU,GAAG,WAAW,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;IAE/C,OAAO,CACL,eAAK,SAAS,EAAE,GAAG,MAAM,CAAC,aAAa,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,SAAS,EAAE,CAAC,IAAI,EAAE,aAC7E,KAAK,CAAC,CAAC,CAAC,CACP,gBAAO,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,CAAC,KAAK,YAChD,KAAK,GACA,CACT,CAAC,CAAC,CAAC,IAAI,EACR,cAAK,SAAS,EAAE,MAAM,CAAC,iBAAiB,YACtC,mBAAU,EAAE,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,CAAC,QAAQ,KAAM,KAAK,GAAI,GAC/D,IACF,CACP,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"CyberpunkTextarea.js","sourceRoot":"","sources":["../../src/components/CyberpunkTextarea.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AACtD,OAAO,MAAM,MAAM,gCAAgC,CAAC;AAOpD,MAAM,UAAU,iBAAiB,CAAC,EAChC,KAAK,EACL,OAAO,GAAG,SAAS,EACnB,SAAS,GAAG,EAAE,EACd,EAAE,EACF,GAAG,KAAK,EACe;IACvB,MAAM,UAAU,GAAG,WAAW,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;IAE/C,OAAO,CACL,eAAK,SAAS,EAAE,GAAG,MAAM,CAAC,aAAa,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,SAAS,EAAE,CAAC,IAAI,EAAE,aAC7E,KAAK,CAAC,CAAC,CAAC,CACP,gBAAO,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,CAAC,KAAK,YAChD,KAAK,GACA,CACT,CAAC,CAAC,CAAC,IAAI,EACR,cAAK,SAAS,EAAE,MAAM,CAAC,iBAAiB,YACtC,mBAAU,EAAE,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,CAAC,QAAQ,KAAM,KAAK,GAAI,GAC/D,IACF,CACP,CAAC;AACJ,CAAC"}
@@ -0,0 +1,19 @@
1
+ export interface HeartbeatPulseProps {
2
+ intervalMinutes?: number;
3
+ size?: number;
4
+ width?: number;
5
+ height?: number;
6
+ color?: string;
7
+ active?: boolean;
8
+ variant?: "orb" | "line";
9
+ className?: string;
10
+ }
11
+ export declare function HeartbeatPulse({ intervalMinutes, size, width, height, color, active, variant, className, }: HeartbeatPulseProps): import("react/jsx-runtime").JSX.Element;
12
+ export interface HeartbeatIndicatorProps {
13
+ intervalMinutes?: number;
14
+ active?: boolean;
15
+ label?: string;
16
+ color?: string;
17
+ }
18
+ export declare function HeartbeatIndicator({ intervalMinutes, active, label, color, }: HeartbeatIndicatorProps): import("react/jsx-runtime").JSX.Element;
19
+ //# sourceMappingURL=HeartbeatPulse.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"HeartbeatPulse.d.ts","sourceRoot":"","sources":["../../src/components/HeartbeatPulse.tsx"],"names":[],"mappings":"AAIA,MAAM,WAAW,mBAAmB;IAClC,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,OAAO,CAAC,EAAE,KAAK,GAAG,MAAM,CAAC;IACzB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,wBAAgB,cAAc,CAAC,EAC7B,eAAoB,EACpB,IAAS,EACT,KAAK,EACL,MAAM,EACN,KAA+B,EAC/B,MAAa,EACb,OAAe,EACf,SAAc,GACf,EAAE,mBAAmB,2CAiNrB;AAED,MAAM,WAAW,uBAAuB;IACtC,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,wBAAgB,kBAAkB,CAAC,EACjC,eAAoB,EACpB,MAAa,EACb,KAAK,EACL,KAAK,GACN,EAAE,uBAAuB,2CAyBzB"}
@@ -0,0 +1,33 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import React from "react";
3
+ import styles from "./HeartbeatPulse.module.css";
4
+ export function HeartbeatPulse({ intervalMinutes = 30, size = 24, width, height, color = "var(--accent-primary)", active = true, variant = "orb", className = "", }) {
5
+ const baseDuration = variant === "line"
6
+ ? Math.max(1.9, Math.min(2.4, intervalMinutes / 15))
7
+ : 1.2;
8
+ const animationDuration = active ? `${baseDuration}s` : "0s";
9
+ const instanceId = React.useId().replace(/:/g, "-");
10
+ if (variant === "line") {
11
+ const lineWidth = width ?? Math.max(size * 3, 200);
12
+ const lineHeight = height ?? Math.max(size, 72);
13
+ const clipId = `heartbeat-line-clip-${instanceId}`;
14
+ return (_jsx("div", { className: `${styles.pulseRoot} ${styles.lineRoot} ${className}`.trim(), children: _jsxs("svg", { viewBox: "0 0 200 100", width: lineWidth, height: lineHeight, className: styles.svg, "aria-hidden": "true", children: [_jsx("defs", { children: _jsx("clipPath", { id: clipId, children: _jsxs("rect", { x: "0", y: "0", width: "0", height: "100", children: [_jsx("animate", { attributeName: "width", values: "0;200;200;0", dur: animationDuration, repeatCount: "indefinite", calcMode: "linear", keyTimes: "0;0.48;0.52;1" }), _jsx("animate", { attributeName: "x", values: "0;0;0;200", dur: animationDuration, repeatCount: "indefinite", calcMode: "linear", keyTimes: "0;0.48;0.52;1" })] }) }) }), _jsx("line", { x1: "2", y1: "58.7", x2: "198", y2: "58.7", stroke: color, strokeWidth: "3", strokeOpacity: active ? "0.18" : "0.08", strokeLinecap: "round" }), _jsx("g", { clipPath: `url(#${clipId})`, children: _jsx("polyline", { fill: "none", strokeWidth: "3", stroke: active ? color : "var(--text-muted)", strokeLinecap: "round", strokeLinejoin: "round", points: "2.4,58.7 70.8,58.7 76.1,46.2 81.1,58.7 89.9,58.7 93.8,66.5 102.8,22.7 110.6,78.7 115.3,58.7 126.4,58.7 134.4,54.7 142.4,58.7 197.8,58.7", opacity: active ? "1" : "0.35" }) })] }) }));
15
+ }
16
+ const viewBoxSize = 100;
17
+ const center = viewBoxSize / 2;
18
+ const radius = size / 2 - 4;
19
+ const clipId = `heartbeat-clip-${instanceId}`;
20
+ return (_jsx("div", { className: `${styles.pulseRoot} ${className}`.trim(), children: _jsxs("svg", { viewBox: `0 0 ${viewBoxSize} ${viewBoxSize}`, width: size, height: size, className: styles.svg, "aria-hidden": "true", children: [_jsx("defs", { children: _jsx("clipPath", { id: clipId, children: _jsx("rect", { x: "0", y: "0", width: viewBoxSize, height: viewBoxSize, children: _jsx("animate", { attributeName: "x", values: `${viewBoxSize};0;0;${viewBoxSize}`, dur: animationDuration, repeatCount: "indefinite", calcMode: "spline", keySplines: "0.4 0 0.2 1; 0.4 0 0.2 1; 0.4 0 0.2 1", keyTimes: "0;0.5;0.5;1" }) }) }) }), _jsx("circle", { cx: center, cy: center, r: radius, fill: "none", stroke: color, strokeWidth: "2", opacity: "0.3" }), active ? (_jsxs(_Fragment, { children: [_jsxs("circle", { cx: center, cy: center, r: radius, fill: "none", stroke: color, strokeWidth: "2", opacity: "0", children: [_jsx("animate", { attributeName: "r", values: `${radius * 0.8};${radius}`, dur: animationDuration, repeatCount: "indefinite" }), _jsx("animate", { attributeName: "opacity", values: "0.6;0", dur: animationDuration, repeatCount: "indefinite" })] }), _jsxs("circle", { cx: center, cy: center, r: radius, fill: "none", stroke: color, strokeWidth: "1", opacity: "0", children: [_jsx("animate", { attributeName: "r", values: `${radius * 0.5};${radius}`, dur: animationDuration, repeatCount: "indefinite", begin: "0.2s" }), _jsx("animate", { attributeName: "opacity", values: "0.4;0", dur: animationDuration, repeatCount: "indefinite", begin: "0.2s" })] })] })) : null, _jsx("circle", { cx: center, cy: center, r: radius * 0.25, fill: active ? color : "var(--text-muted)", children: active ? (_jsx("animate", { attributeName: "r", values: `${radius * 0.25};${radius * 0.3};${radius * 0.25}`, dur: animationDuration, repeatCount: "indefinite" })) : null }), active ? (_jsx("g", { clipPath: `url(#${clipId})`, children: _jsx("path", { d: `M 0 ${center}
21
+ L ${center * 0.3} ${center}
22
+ L ${center * 0.4} ${center}
23
+ L ${center * 0.5} ${center * 0.2}
24
+ L ${center * 0.6} ${center * 1.8}
25
+ L ${center * 0.7} ${center}
26
+ L ${viewBoxSize} ${center}`, fill: "none", stroke: color, strokeWidth: "2", strokeLinecap: "round", strokeLinejoin: "round", opacity: "0.7", children: _jsx("animate", { attributeName: "opacity", values: "0;0.7;0", dur: animationDuration, repeatCount: "indefinite" }) }) })) : null] }) }));
27
+ }
28
+ export function HeartbeatIndicator({ intervalMinutes = 30, active = true, label, color, }) {
29
+ return (_jsxs("div", { className: styles.indicator, children: [_jsx(HeartbeatPulse, { intervalMinutes: intervalMinutes, active: active, size: 20, color: color }), label !== undefined ? (_jsx("span", { className: `${styles.indicatorLabel} ${active ? styles.indicatorLabelActive : styles.indicatorLabelInactive}`.trim(), style: color
30
+ ? { ["--heartbeat-indicator-color"]: color }
31
+ : undefined, children: label })) : null] }));
32
+ }
33
+ //# sourceMappingURL=HeartbeatPulse.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"HeartbeatPulse.js","sourceRoot":"","sources":["../../src/components/HeartbeatPulse.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,34 @@
1
+ .pulseRoot {
2
+ display: inline-block;
3
+ }
4
+
5
+ .lineRoot {
6
+ line-height: 0;
7
+ }
8
+
9
+ .svg {
10
+ width: 100%;
11
+ height: 100%;
12
+ overflow: visible;
13
+ }
14
+
15
+ .indicator {
16
+ display: flex;
17
+ align-items: center;
18
+ gap: 0.5rem;
19
+ }
20
+
21
+ .indicatorLabel {
22
+ font-family: var(--font-mono);
23
+ font-size: 0.75rem;
24
+ font-weight: 500;
25
+ letter-spacing: 0.04em;
26
+ }
27
+
28
+ .indicatorLabelActive {
29
+ color: var(--heartbeat-indicator-color, var(--accent-primary));
30
+ }
31
+
32
+ .indicatorLabelInactive {
33
+ color: var(--text-muted);
34
+ }
@@ -0,0 +1,13 @@
1
+ import React from "react";
2
+ export interface MarqueeStripProps<T> extends React.HTMLAttributes<HTMLDivElement> {
3
+ items: readonly T[];
4
+ renderItem: (item: T, index: number) => React.ReactNode;
5
+ ariaLabel?: string;
6
+ durationSeconds?: number;
7
+ gap?: number | string;
8
+ pauseOnHover?: boolean;
9
+ trackClassName?: string;
10
+ itemClassName?: string;
11
+ }
12
+ export declare function MarqueeStrip<T>({ items, renderItem, ariaLabel, durationSeconds, gap, pauseOnHover, className, trackClassName, itemClassName, style, ...props }: MarqueeStripProps<T>): import("react/jsx-runtime").JSX.Element;
13
+ //# sourceMappingURL=MarqueeStrip.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MarqueeStrip.d.ts","sourceRoot":"","sources":["../../src/components/MarqueeStrip.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,MAAM,WAAW,iBAAiB,CAAC,CAAC,CAAE,SAAQ,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC;IAChF,KAAK,EAAE,SAAS,CAAC,EAAE,CAAC;IACpB,UAAU,EAAE,CAAC,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,MAAM,KAAK,KAAK,CAAC,SAAS,CAAC;IACxD,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,GAAG,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACtB,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB;AAED,wBAAgB,YAAY,CAAC,CAAC,EAAE,EAC9B,KAAK,EACL,UAAU,EACV,SAAS,EACT,eAAoB,EACpB,GAAc,EACd,YAAoB,EACpB,SAAc,EACd,cAAmB,EACnB,aAAkB,EAClB,KAAK,EACL,GAAG,KAAK,EACT,EAAE,iBAAiB,CAAC,CAAC,CAAC,2CA6BtB"}
@@ -0,0 +1,12 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import styles from "./MarqueeStrip.module.css";
3
+ export function MarqueeStrip({ items, renderItem, ariaLabel, durationSeconds = 24, gap = "0.7rem", pauseOnHover = false, className = "", trackClassName = "", itemClassName = "", style, ...props }) {
4
+ const doubledItems = [...items, ...items];
5
+ const mergedStyle = {
6
+ ...style,
7
+ ["--marquee-duration"]: `${durationSeconds}s`,
8
+ ["--marquee-gap"]: typeof gap === "number" ? `${gap}px` : gap,
9
+ };
10
+ return (_jsx("div", { className: `${styles.root} ${pauseOnHover ? styles.pauseOnHover : ""} ${className}`.trim(), "aria-label": ariaLabel, style: mergedStyle, ...props, children: _jsx("div", { className: `${styles.track} ${trackClassName}`.trim(), children: doubledItems.map((item, index) => (_jsx("div", { className: `${styles.item} ${itemClassName}`.trim(), "aria-hidden": index >= items.length, children: renderItem(item, index % items.length) }, index))) }) }));
11
+ }
12
+ //# sourceMappingURL=MarqueeStrip.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MarqueeStrip.js","sourceRoot":"","sources":["../../src/components/MarqueeStrip.tsx"],"names":[],"mappings":";AAEA,OAAO,MAAM,MAAM,2BAA2B,CAAC;AAa/C,MAAM,UAAU,YAAY,CAAI,EAC9B,KAAK,EACL,UAAU,EACV,SAAS,EACT,eAAe,GAAG,EAAE,EACpB,GAAG,GAAG,QAAQ,EACd,YAAY,GAAG,KAAK,EACpB,SAAS,GAAG,EAAE,EACd,cAAc,GAAG,EAAE,EACnB,aAAa,GAAG,EAAE,EAClB,KAAK,EACL,GAAG,KAAK,EACa;IACrB,MAAM,YAAY,GAAG,CAAC,GAAG,KAAK,EAAE,GAAG,KAAK,CAAC,CAAC;IAC1C,MAAM,WAAW,GAAG;QAClB,GAAG,KAAK;QACR,CAAC,oBAA8B,CAAC,EAAE,GAAG,eAAe,GAAG;QACvD,CAAC,eAAyB,CAAC,EACzB,OAAO,GAAG,KAAK,QAAQ,CAAC,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,GAAG;KACtB,CAAC;IAEzB,OAAO,CACL,cACE,SAAS,EAAE,GAAG,MAAM,CAAC,IAAI,IAAI,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,EAAE,IAAI,SAAS,EAAE,CAAC,IAAI,EAAE,gBAC9E,SAAS,EACrB,KAAK,EAAE,WAAW,KACd,KAAK,YAET,cAAK,SAAS,EAAE,GAAG,MAAM,CAAC,KAAK,IAAI,cAAc,EAAE,CAAC,IAAI,EAAE,YACvD,YAAY,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,CACjC,cAEE,SAAS,EAAE,GAAG,MAAM,CAAC,IAAI,IAAI,aAAa,EAAE,CAAC,IAAI,EAAE,iBACtC,KAAK,IAAI,KAAK,CAAC,MAAM,YAEjC,UAAU,CAAC,IAAI,EAAE,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,IAJlC,KAAK,CAKN,CACP,CAAC,GACE,GACF,CACP,CAAC;AACJ,CAAC"}
@@ -0,0 +1,36 @@
1
+ .root {
2
+ position: relative;
3
+ overflow: hidden;
4
+ }
5
+
6
+ .track {
7
+ display: flex;
8
+ align-items: center;
9
+ gap: var(--marquee-gap, 0.7rem);
10
+ width: max-content;
11
+ animation: marqueeStrip var(--marquee-duration, 24s) linear infinite;
12
+ }
13
+
14
+ .pauseOnHover:hover .track {
15
+ animation-play-state: paused;
16
+ }
17
+
18
+ .item {
19
+ flex: 0 0 auto;
20
+ }
21
+
22
+ @keyframes marqueeStrip {
23
+ from {
24
+ transform: translateX(0);
25
+ }
26
+
27
+ to {
28
+ transform: translateX(calc(-50% - (var(--marquee-gap, 0.7rem) / 2)));
29
+ }
30
+ }
31
+
32
+ @media (prefers-reduced-motion: reduce) {
33
+ .track {
34
+ animation: none;
35
+ }
36
+ }
@@ -1,5 +1,5 @@
1
1
  import React from "react";
2
- import { type PageHeaderProps } from "./PageHeader";
2
+ import { type PageHeaderProps } from "./PageHeader.js";
3
3
  interface SubTab {
4
4
  id: string;
5
5
  label: string;
@@ -1 +1 @@
1
- {"version":3,"file":"PageTemplate.d.ts","sourceRoot":"","sources":["../../src/components/PageTemplate.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAc,KAAK,eAAe,EAAE,MAAM,cAAc,CAAC;AAGhE,UAAU,MAAM;IACd,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,iBACf,SAAQ,IAAI,CACV,eAAe,EACb,OAAO,GACP,aAAa,GACb,MAAM,GACN,QAAQ,GACR,YAAY,GACZ,OAAO,GACP,cAAc,GACd,gBAAgB,GAChB,eAAe,CAClB;IACD,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,KAAK,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACxB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACnB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,cAAc,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACzC,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC3B,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B;AAED,wBAAgB,YAAY,CAAC,EAC3B,KAAK,EACL,OAAO,EACP,KAAK,EACL,WAAW,EACX,IAAI,EACJ,OAAO,EACP,YAAY,EACZ,cAAc,EACd,MAAM,EACN,UAAU,EACV,KAAK,EACL,YAAY,EACZ,cAAc,EACd,aAAa,EACb,UAAU,EACV,cAAc,EACd,eAAe,EACf,eAAe,EACf,QAAQ,EACR,OAAO,EACP,SAAgB,EAChB,SAAc,GACf,EAAE,iBAAiB,2CAgDnB"}
1
+ {"version":3,"file":"PageTemplate.d.ts","sourceRoot":"","sources":["../../src/components/PageTemplate.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAc,KAAK,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAGnE,UAAU,MAAM;IACd,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,iBACf,SAAQ,IAAI,CACV,eAAe,EACb,OAAO,GACP,aAAa,GACb,MAAM,GACN,QAAQ,GACR,YAAY,GACZ,OAAO,GACP,cAAc,GACd,gBAAgB,GAChB,eAAe,CAClB;IACD,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,KAAK,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACxB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IACnB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,cAAc,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACzC,QAAQ,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC3B,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B;AAED,wBAAgB,YAAY,CAAC,EAC3B,KAAK,EACL,OAAO,EACP,KAAK,EACL,WAAW,EACX,IAAI,EACJ,OAAO,EACP,YAAY,EACZ,cAAc,EACd,MAAM,EACN,UAAU,EACV,KAAK,EACL,YAAY,EACZ,cAAc,EACd,aAAa,EACb,UAAU,EACV,cAAc,EACd,eAAe,EACf,eAAe,EACf,QAAQ,EACR,OAAO,EACP,SAAgB,EAChB,SAAc,GACf,EAAE,iBAAiB,2CAgDnB"}
@@ -1,5 +1,5 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { PageHeader } from "./PageHeader";
2
+ import { PageHeader } from "./PageHeader.js";
3
3
  import styles from "./PageTemplate.module.css";
4
4
  export function PageTemplate({ title, actions, extra, description, icon, subTabs, activeSubTab, onSubTabChange, onBack, onSettings, brand, onBrandClick, onViewerToggle, viewerVisible, brandTitle, brandAriaLabel, viewerShowLabel, viewerHideLabel, children, loading, showTitle = true, className = "", }) {
5
5
  const headerExtra = extra ?? actions;
@@ -1 +1 @@
1
- {"version":3,"file":"PageTemplate.js","sourceRoot":"","sources":["../../src/components/PageTemplate.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAE,UAAU,EAAwB,MAAM,cAAc,CAAC;AAChE,OAAO,MAAM,MAAM,2BAA2B,CAAC;AAmC/C,MAAM,UAAU,YAAY,CAAC,EAC3B,KAAK,EACL,OAAO,EACP,KAAK,EACL,WAAW,EACX,IAAI,EACJ,OAAO,EACP,YAAY,EACZ,cAAc,EACd,MAAM,EACN,UAAU,EACV,KAAK,EACL,YAAY,EACZ,cAAc,EACd,aAAa,EACb,UAAU,EACV,cAAc,EACd,eAAe,EACf,eAAe,EACf,QAAQ,EACR,OAAO,EACP,SAAS,GAAG,IAAI,EAChB,SAAS,GAAG,EAAE,GACI;IAClB,MAAM,WAAW,GAAG,KAAK,IAAI,OAAO,CAAC;IAErC,OAAO,CACL,eAAK,SAAS,EAAE,GAAG,MAAM,CAAC,IAAI,IAAI,SAAS,EAAE,CAAC,IAAI,EAAE,aACjD,SAAS,CAAC,CAAC,CAAC,CACX,cAAK,SAAS,EAAE,MAAM,CAAC,MAAM,YAC3B,KAAC,UAAU,IACT,KAAK,EAAE,KAAK,EACZ,WAAW,EAAE,WAAW,EACxB,IAAI,EAAE,IAAI,EACV,KAAK,EAAE,WAAW,EAClB,MAAM,EAAE,MAAM,EACd,UAAU,EAAE,UAAU,EACtB,KAAK,EAAE,KAAK,EACZ,YAAY,EAAE,YAAY,EAC1B,UAAU,EAAE,UAAU,EACtB,cAAc,EAAE,cAAc,EAC9B,cAAc,EAAE,cAAc,EAC9B,aAAa,EAAE,aAAa,EAC5B,eAAe,EAAE,eAAe,EAChC,eAAe,EAAE,eAAe,GAChC,GACE,CACP,CAAC,CAAC,CAAC,IAAI,EAEP,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,CACjB,cAAK,SAAS,EAAE,MAAM,CAAC,OAAO,EAAE,IAAI,EAAC,SAAS,gBAAa,GAAG,KAAK,WAAW,YAC3E,OAAO,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CACpB,iBAEE,OAAO,EAAE,GAAG,EAAE,CAAC,cAAc,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EACvC,SAAS,EAAE,GAAG,MAAM,CAAC,YAAY,IAAI,YAAY,KAAK,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,EAAE,EACtG,IAAI,EAAC,QAAQ,EACb,IAAI,EAAC,KAAK,mBACK,YAAY,KAAK,GAAG,CAAC,EAAE,YAErC,GAAG,CAAC,KAAK,IAPL,GAAG,CAAC,EAAE,CAQJ,CACV,CAAC,GACE,CACP,CAAC,CAAC,CAAC,IAAI,EAER,cAAK,SAAS,EAAE,MAAM,CAAC,OAAO,YAC3B,OAAO,CAAC,CAAC,CAAC,cAAK,SAAS,EAAE,MAAM,CAAC,OAAO,2BAAkB,CAAC,CAAC,CAAC,QAAQ,IAAI,IAAI,GAC1E,IACF,CACP,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"PageTemplate.js","sourceRoot":"","sources":["../../src/components/PageTemplate.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAE,UAAU,EAAwB,MAAM,iBAAiB,CAAC;AACnE,OAAO,MAAM,MAAM,2BAA2B,CAAC;AAmC/C,MAAM,UAAU,YAAY,CAAC,EAC3B,KAAK,EACL,OAAO,EACP,KAAK,EACL,WAAW,EACX,IAAI,EACJ,OAAO,EACP,YAAY,EACZ,cAAc,EACd,MAAM,EACN,UAAU,EACV,KAAK,EACL,YAAY,EACZ,cAAc,EACd,aAAa,EACb,UAAU,EACV,cAAc,EACd,eAAe,EACf,eAAe,EACf,QAAQ,EACR,OAAO,EACP,SAAS,GAAG,IAAI,EAChB,SAAS,GAAG,EAAE,GACI;IAClB,MAAM,WAAW,GAAG,KAAK,IAAI,OAAO,CAAC;IAErC,OAAO,CACL,eAAK,SAAS,EAAE,GAAG,MAAM,CAAC,IAAI,IAAI,SAAS,EAAE,CAAC,IAAI,EAAE,aACjD,SAAS,CAAC,CAAC,CAAC,CACX,cAAK,SAAS,EAAE,MAAM,CAAC,MAAM,YAC3B,KAAC,UAAU,IACT,KAAK,EAAE,KAAK,EACZ,WAAW,EAAE,WAAW,EACxB,IAAI,EAAE,IAAI,EACV,KAAK,EAAE,WAAW,EAClB,MAAM,EAAE,MAAM,EACd,UAAU,EAAE,UAAU,EACtB,KAAK,EAAE,KAAK,EACZ,YAAY,EAAE,YAAY,EAC1B,UAAU,EAAE,UAAU,EACtB,cAAc,EAAE,cAAc,EAC9B,cAAc,EAAE,cAAc,EAC9B,aAAa,EAAE,aAAa,EAC5B,eAAe,EAAE,eAAe,EAChC,eAAe,EAAE,eAAe,GAChC,GACE,CACP,CAAC,CAAC,CAAC,IAAI,EAEP,OAAO,EAAE,MAAM,CAAC,CAAC,CAAC,CACjB,cAAK,SAAS,EAAE,MAAM,CAAC,OAAO,EAAE,IAAI,EAAC,SAAS,gBAAa,GAAG,KAAK,WAAW,YAC3E,OAAO,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CACpB,iBAEE,OAAO,EAAE,GAAG,EAAE,CAAC,cAAc,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EACvC,SAAS,EAAE,GAAG,MAAM,CAAC,YAAY,IAAI,YAAY,KAAK,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,EAAE,EACtG,IAAI,EAAC,QAAQ,EACb,IAAI,EAAC,KAAK,mBACK,YAAY,KAAK,GAAG,CAAC,EAAE,YAErC,GAAG,CAAC,KAAK,IAPL,GAAG,CAAC,EAAE,CAQJ,CACV,CAAC,GACE,CACP,CAAC,CAAC,CAAC,IAAI,EAER,cAAK,SAAS,EAAE,MAAM,CAAC,OAAO,YAC3B,OAAO,CAAC,CAAC,CAAC,cAAK,SAAS,EAAE,MAAM,CAAC,OAAO,2BAAkB,CAAC,CAAC,CAAC,QAAQ,IAAI,IAAI,GAC1E,IACF,CACP,CAAC;AACJ,CAAC"}
@@ -0,0 +1,10 @@
1
+ import React from "react";
2
+ export interface StrokedTextProps extends React.HTMLAttributes<HTMLSpanElement> {
3
+ children: React.ReactNode;
4
+ color?: string;
5
+ strokeWidth?: number | string;
6
+ animateOnMount?: boolean;
7
+ fallbackOpacity?: number;
8
+ }
9
+ export declare function StrokedText({ children, color, strokeWidth, animateOnMount, fallbackOpacity, className, style, ...props }: StrokedTextProps): import("react/jsx-runtime").JSX.Element;
10
+ //# sourceMappingURL=StrokedText.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StrokedText.d.ts","sourceRoot":"","sources":["../../src/components/StrokedText.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,MAAM,WAAW,gBAAiB,SAAQ,KAAK,CAAC,cAAc,CAAC,eAAe,CAAC;IAC7E,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAC9B,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B;AAED,wBAAgB,WAAW,CAAC,EAC1B,QAAQ,EACR,KAAK,EACL,WAAyC,EACzC,cAAsB,EACtB,eAAsB,EACtB,SAAc,EACd,KAAK,EACL,GAAG,KAAK,EACT,EAAE,gBAAgB,2CAkBlB"}
@@ -0,0 +1,12 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import styles from "./StrokedText.module.css";
3
+ export function StrokedText({ children, color, strokeWidth = "clamp(1px, 0.11vw, 1.8px)", animateOnMount = false, fallbackOpacity = 0.18, className = "", style, ...props }) {
4
+ const mergedStyle = {
5
+ ...style,
6
+ ["--stroked-text-color"]: color,
7
+ ["--stroked-text-width"]: typeof strokeWidth === "number" ? `${strokeWidth}px` : strokeWidth,
8
+ ["--stroked-text-fallback-opacity"]: String(fallbackOpacity),
9
+ };
10
+ return (_jsx("span", { className: `${styles.root} ${animateOnMount ? styles.animateOnMount : ""} ${className}`.trim(), style: mergedStyle, ...props, children: children }));
11
+ }
12
+ //# sourceMappingURL=StrokedText.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StrokedText.js","sourceRoot":"","sources":["../../src/components/StrokedText.tsx"],"names":[],"mappings":";AAEA,OAAO,MAAM,MAAM,0BAA0B,CAAC;AAU9C,MAAM,UAAU,WAAW,CAAC,EAC1B,QAAQ,EACR,KAAK,EACL,WAAW,GAAG,2BAA2B,EACzC,cAAc,GAAG,KAAK,EACtB,eAAe,GAAG,IAAI,EACtB,SAAS,GAAG,EAAE,EACd,KAAK,EACL,GAAG,KAAK,EACS;IACjB,MAAM,WAAW,GAAG;QAClB,GAAG,KAAK;QACR,CAAC,sBAAgC,CAAC,EAAE,KAAK;QACzC,CAAC,sBAAgC,CAAC,EAChC,OAAO,WAAW,KAAK,QAAQ,CAAC,CAAC,CAAC,GAAG,WAAW,IAAI,CAAC,CAAC,CAAC,WAAW;QACpE,CAAC,iCAA2C,CAAC,EAAE,MAAM,CAAC,eAAe,CAAC;KAChD,CAAC;IAEzB,OAAO,CACL,eACE,SAAS,EAAE,GAAG,MAAM,CAAC,IAAI,IAAI,cAAc,CAAC,CAAC,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC,EAAE,IAAI,SAAS,EAAE,CAAC,IAAI,EAAE,EAC9F,KAAK,EAAE,WAAW,KACd,KAAK,YAER,QAAQ,GACJ,CACR,CAAC;AACJ,CAAC"}
@@ -0,0 +1,63 @@
1
+ .root {
2
+ display: inline-flex;
3
+ align-items: center;
4
+ color: transparent;
5
+ -webkit-text-stroke: var(--stroked-text-width, 1px)
6
+ var(--stroked-text-color, var(--accent-primary));
7
+ paint-order: stroke fill;
8
+ white-space: nowrap;
9
+ }
10
+
11
+ .animateOnMount {
12
+ animation: strokedTextBlink 1s steps(1, end) 0.18s both;
13
+ }
14
+
15
+ @supports not (-webkit-text-stroke: 1px black) {
16
+ .root {
17
+ color: var(--stroked-text-color, var(--accent-primary));
18
+ }
19
+
20
+ .animateOnMount {
21
+ animation: strokedTextFallbackBlink 1s steps(1, end) 0.18s both;
22
+ }
23
+ }
24
+
25
+ @keyframes strokedTextBlink {
26
+ 0%,
27
+ 14%,
28
+ 32%,
29
+ 50%,
30
+ 68%,
31
+ 100% {
32
+ color: transparent;
33
+ -webkit-text-stroke-color: var(--stroked-text-color, var(--accent-primary));
34
+ }
35
+
36
+ 18%,
37
+ 36%,
38
+ 54%,
39
+ 72%,
40
+ 90% {
41
+ color: var(--stroked-text-color, var(--accent-primary));
42
+ -webkit-text-stroke-color: transparent;
43
+ }
44
+ }
45
+
46
+ @keyframes strokedTextFallbackBlink {
47
+ 0%,
48
+ 14%,
49
+ 32%,
50
+ 50%,
51
+ 68%,
52
+ 100% {
53
+ opacity: var(--stroked-text-fallback-opacity, 0.18);
54
+ }
55
+
56
+ 18%,
57
+ 36%,
58
+ 54%,
59
+ 72%,
60
+ 90% {
61
+ opacity: 1;
62
+ }
63
+ }
package/dist/index.d.ts CHANGED
@@ -1,20 +1,25 @@
1
- export { Button, type ButtonProps } from "./components/Button";
2
- export { CopyButton, type CopyButtonProps } from "./components/CopyButton";
3
- export { CyberpunkCheckbox, type CyberpunkCheckboxProps } from "./components/CyberpunkCheckbox";
4
- export { CyberpunkInput, type CyberpunkInputProps, } from "./components/CyberpunkInput";
5
- export { CyberpunkRadio, CyberpunkRadioGroup, type CyberpunkRadioGroupProps, type CyberpunkRadioProps, } from "./components/CyberpunkRadio";
6
- export { CyberpunkSelect, type CyberpunkSelectOption, type CyberpunkSelectProps, } from "./components/CyberpunkSelect";
7
- export { CyberpunkSlider, type CyberpunkSliderProps, } from "./components/CyberpunkSlider";
8
- export { CyberpunkTextarea, type CyberpunkTextareaProps, } from "./components/CyberpunkTextarea";
9
- export { CyberpunkTile, type CyberpunkTileProps } from "./components/CyberpunkTile";
10
- export { CornerBracketCard, type CornerBracketCardProps } from "./components/CornerBracketCard";
11
- export { ErrorMessage, type ErrorMessageProps } from "./components/ErrorMessage";
12
- export { LOADING_PROGRESS_SEGMENT_COUNT, LoadingProgressBar, type LoadingProgressBarProps, } from "./components/LoadingProgressBar";
13
- export { PageHeader, type PageHeaderProps } from "./components/PageHeader";
14
- export { PageTemplate, type PageTemplateProps } from "./components/PageTemplate";
15
- export { SegmentedControl, type SegmentedControlOption, type SegmentedControlProps, } from "./components/SegmentedControl";
16
- export { StatusMessage, type StatusMessageProps } from "./components/StatusMessage";
17
- export { TabbedPanel, type TabbedPanelProps, type TabbedPanelTab } from "./components/TabbedPanel";
18
- export { ThemedCard, type ThemedCardProps } from "./components/ThemedCard";
19
- export { ThemeToggle, type ThemeToggleProps } from "./components/ThemeToggle";
1
+ export { AvatarStage, type AvatarStageProps } from "./components/AvatarStage.js";
2
+ export { BlinkText, type BlinkTextProps } from "./components/BlinkText.js";
3
+ export { Button, type ButtonProps } from "./components/Button.js";
4
+ export { CopyButton, type CopyButtonProps } from "./components/CopyButton.js";
5
+ export { CyberpunkCheckbox, type CyberpunkCheckboxProps } from "./components/CyberpunkCheckbox.js";
6
+ export { CyberpunkInput, type CyberpunkInputProps, } from "./components/CyberpunkInput.js";
7
+ export { CyberpunkRadio, CyberpunkRadioGroup, type CyberpunkRadioGroupProps, type CyberpunkRadioProps, } from "./components/CyberpunkRadio.js";
8
+ export { CyberpunkSelect, type CyberpunkSelectOption, type CyberpunkSelectProps, } from "./components/CyberpunkSelect.js";
9
+ export { CyberpunkSlider, type CyberpunkSliderProps, } from "./components/CyberpunkSlider.js";
10
+ export { CyberpunkTextarea, type CyberpunkTextareaProps, } from "./components/CyberpunkTextarea.js";
11
+ export { CyberpunkTile, type CyberpunkTileProps } from "./components/CyberpunkTile.js";
12
+ export { CornerBracketCard, type CornerBracketCardProps } from "./components/CornerBracketCard.js";
13
+ export { ErrorMessage, type ErrorMessageProps } from "./components/ErrorMessage.js";
14
+ export { HeartbeatIndicator, HeartbeatPulse, type HeartbeatIndicatorProps, type HeartbeatPulseProps, } from "./components/HeartbeatPulse.js";
15
+ export { LOADING_PROGRESS_SEGMENT_COUNT, LoadingProgressBar, type LoadingProgressBarProps, } from "./components/LoadingProgressBar.js";
16
+ export { MarqueeStrip, type MarqueeStripProps } from "./components/MarqueeStrip.js";
17
+ export { PageHeader, type PageHeaderProps } from "./components/PageHeader.js";
18
+ export { PageTemplate, type PageTemplateProps } from "./components/PageTemplate.js";
19
+ export { SegmentedControl, type SegmentedControlOption, type SegmentedControlProps, } from "./components/SegmentedControl.js";
20
+ export { StatusMessage, type StatusMessageProps } from "./components/StatusMessage.js";
21
+ export { StrokedText, type StrokedTextProps } from "./components/StrokedText.js";
22
+ export { TabbedPanel, type TabbedPanelProps, type TabbedPanelTab } from "./components/TabbedPanel.js";
23
+ export { ThemedCard, type ThemedCardProps } from "./components/ThemedCard.js";
24
+ export { ThemeToggle, type ThemeToggleProps } from "./components/ThemeToggle.js";
20
25
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,KAAK,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAC/D,OAAO,EAAE,UAAU,EAAE,KAAK,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC3E,OAAO,EAAE,iBAAiB,EAAE,KAAK,sBAAsB,EAAE,MAAM,gCAAgC,CAAC;AAChG,OAAO,EACL,cAAc,EACd,KAAK,mBAAmB,GACzB,MAAM,6BAA6B,CAAC;AACrC,OAAO,EACL,cAAc,EACd,mBAAmB,EACnB,KAAK,wBAAwB,EAC7B,KAAK,mBAAmB,GACzB,MAAM,6BAA6B,CAAC;AACrC,OAAO,EACL,eAAe,EACf,KAAK,qBAAqB,EAC1B,KAAK,oBAAoB,GAC1B,MAAM,8BAA8B,CAAC;AACtC,OAAO,EACL,eAAe,EACf,KAAK,oBAAoB,GAC1B,MAAM,8BAA8B,CAAC;AACtC,OAAO,EACL,iBAAiB,EACjB,KAAK,sBAAsB,GAC5B,MAAM,gCAAgC,CAAC;AACxC,OAAO,EAAE,aAAa,EAAE,KAAK,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AACpF,OAAO,EAAE,iBAAiB,EAAE,KAAK,sBAAsB,EAAE,MAAM,gCAAgC,CAAC;AAChG,OAAO,EAAE,YAAY,EAAE,KAAK,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AACjF,OAAO,EACL,8BAA8B,EAC9B,kBAAkB,EAClB,KAAK,uBAAuB,GAC7B,MAAM,iCAAiC,CAAC;AACzC,OAAO,EAAE,UAAU,EAAE,KAAK,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC3E,OAAO,EAAE,YAAY,EAAE,KAAK,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AACjF,OAAO,EACL,gBAAgB,EAChB,KAAK,sBAAsB,EAC3B,KAAK,qBAAqB,GAC3B,MAAM,+BAA+B,CAAC;AACvC,OAAO,EAAE,aAAa,EAAE,KAAK,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AACpF,OAAO,EAAE,WAAW,EAAE,KAAK,gBAAgB,EAAE,KAAK,cAAc,EAAE,MAAM,0BAA0B,CAAC;AACnG,OAAO,EAAE,UAAU,EAAE,KAAK,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC3E,OAAO,EAAE,WAAW,EAAE,KAAK,gBAAgB,EAAE,MAAM,0BAA0B,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,KAAK,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;AACjF,OAAO,EAAE,SAAS,EAAE,KAAK,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAC3E,OAAO,EAAE,MAAM,EAAE,KAAK,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAClE,OAAO,EAAE,UAAU,EAAE,KAAK,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC9E,OAAO,EAAE,iBAAiB,EAAE,KAAK,sBAAsB,EAAE,MAAM,mCAAmC,CAAC;AACnG,OAAO,EACL,cAAc,EACd,KAAK,mBAAmB,GACzB,MAAM,gCAAgC,CAAC;AACxC,OAAO,EACL,cAAc,EACd,mBAAmB,EACnB,KAAK,wBAAwB,EAC7B,KAAK,mBAAmB,GACzB,MAAM,gCAAgC,CAAC;AACxC,OAAO,EACL,eAAe,EACf,KAAK,qBAAqB,EAC1B,KAAK,oBAAoB,GAC1B,MAAM,iCAAiC,CAAC;AACzC,OAAO,EACL,eAAe,EACf,KAAK,oBAAoB,GAC1B,MAAM,iCAAiC,CAAC;AACzC,OAAO,EACL,iBAAiB,EACjB,KAAK,sBAAsB,GAC5B,MAAM,mCAAmC,CAAC;AAC3C,OAAO,EAAE,aAAa,EAAE,KAAK,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AACvF,OAAO,EAAE,iBAAiB,EAAE,KAAK,sBAAsB,EAAE,MAAM,mCAAmC,CAAC;AACnG,OAAO,EAAE,YAAY,EAAE,KAAK,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;AACpF,OAAO,EACL,kBAAkB,EAClB,cAAc,EACd,KAAK,uBAAuB,EAC5B,KAAK,mBAAmB,GACzB,MAAM,gCAAgC,CAAC;AACxC,OAAO,EACL,8BAA8B,EAC9B,kBAAkB,EAClB,KAAK,uBAAuB,GAC7B,MAAM,oCAAoC,CAAC;AAC5C,OAAO,EAAE,YAAY,EAAE,KAAK,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;AACpF,OAAO,EAAE,UAAU,EAAE,KAAK,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC9E,OAAO,EAAE,YAAY,EAAE,KAAK,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;AACpF,OAAO,EACL,gBAAgB,EAChB,KAAK,sBAAsB,EAC3B,KAAK,qBAAqB,GAC3B,MAAM,kCAAkC,CAAC;AAC1C,OAAO,EAAE,aAAa,EAAE,KAAK,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AACvF,OAAO,EAAE,WAAW,EAAE,KAAK,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;AACjF,OAAO,EAAE,WAAW,EAAE,KAAK,gBAAgB,EAAE,KAAK,cAAc,EAAE,MAAM,6BAA6B,CAAC;AACtG,OAAO,EAAE,UAAU,EAAE,KAAK,eAAe,EAAE,MAAM,4BAA4B,CAAC;AAC9E,OAAO,EAAE,WAAW,EAAE,KAAK,gBAAgB,EAAE,MAAM,6BAA6B,CAAC"}
package/dist/index.js CHANGED
@@ -1,20 +1,25 @@
1
- export { Button } from "./components/Button";
2
- export { CopyButton } from "./components/CopyButton";
3
- export { CyberpunkCheckbox } from "./components/CyberpunkCheckbox";
4
- export { CyberpunkInput, } from "./components/CyberpunkInput";
5
- export { CyberpunkRadio, CyberpunkRadioGroup, } from "./components/CyberpunkRadio";
6
- export { CyberpunkSelect, } from "./components/CyberpunkSelect";
7
- export { CyberpunkSlider, } from "./components/CyberpunkSlider";
8
- export { CyberpunkTextarea, } from "./components/CyberpunkTextarea";
9
- export { CyberpunkTile } from "./components/CyberpunkTile";
10
- export { CornerBracketCard } from "./components/CornerBracketCard";
11
- export { ErrorMessage } from "./components/ErrorMessage";
12
- export { LOADING_PROGRESS_SEGMENT_COUNT, LoadingProgressBar, } from "./components/LoadingProgressBar";
13
- export { PageHeader } from "./components/PageHeader";
14
- export { PageTemplate } from "./components/PageTemplate";
15
- export { SegmentedControl, } from "./components/SegmentedControl";
16
- export { StatusMessage } from "./components/StatusMessage";
17
- export { TabbedPanel } from "./components/TabbedPanel";
18
- export { ThemedCard } from "./components/ThemedCard";
19
- export { ThemeToggle } from "./components/ThemeToggle";
1
+ export { AvatarStage } from "./components/AvatarStage.js";
2
+ export { BlinkText } from "./components/BlinkText.js";
3
+ export { Button } from "./components/Button.js";
4
+ export { CopyButton } from "./components/CopyButton.js";
5
+ export { CyberpunkCheckbox } from "./components/CyberpunkCheckbox.js";
6
+ export { CyberpunkInput, } from "./components/CyberpunkInput.js";
7
+ export { CyberpunkRadio, CyberpunkRadioGroup, } from "./components/CyberpunkRadio.js";
8
+ export { CyberpunkSelect, } from "./components/CyberpunkSelect.js";
9
+ export { CyberpunkSlider, } from "./components/CyberpunkSlider.js";
10
+ export { CyberpunkTextarea, } from "./components/CyberpunkTextarea.js";
11
+ export { CyberpunkTile } from "./components/CyberpunkTile.js";
12
+ export { CornerBracketCard } from "./components/CornerBracketCard.js";
13
+ export { ErrorMessage } from "./components/ErrorMessage.js";
14
+ export { HeartbeatIndicator, HeartbeatPulse, } from "./components/HeartbeatPulse.js";
15
+ export { LOADING_PROGRESS_SEGMENT_COUNT, LoadingProgressBar, } from "./components/LoadingProgressBar.js";
16
+ export { MarqueeStrip } from "./components/MarqueeStrip.js";
17
+ export { PageHeader } from "./components/PageHeader.js";
18
+ export { PageTemplate } from "./components/PageTemplate.js";
19
+ export { SegmentedControl, } from "./components/SegmentedControl.js";
20
+ export { StatusMessage } from "./components/StatusMessage.js";
21
+ export { StrokedText } from "./components/StrokedText.js";
22
+ export { TabbedPanel } from "./components/TabbedPanel.js";
23
+ export { ThemedCard } from "./components/ThemedCard.js";
24
+ export { ThemeToggle } from "./components/ThemeToggle.js";
20
25
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAoB,MAAM,qBAAqB,CAAC;AAC/D,OAAO,EAAE,UAAU,EAAwB,MAAM,yBAAyB,CAAC;AAC3E,OAAO,EAAE,iBAAiB,EAA+B,MAAM,gCAAgC,CAAC;AAChG,OAAO,EACL,cAAc,GAEf,MAAM,6BAA6B,CAAC;AACrC,OAAO,EACL,cAAc,EACd,mBAAmB,GAGpB,MAAM,6BAA6B,CAAC;AACrC,OAAO,EACL,eAAe,GAGhB,MAAM,8BAA8B,CAAC;AACtC,OAAO,EACL,eAAe,GAEhB,MAAM,8BAA8B,CAAC;AACtC,OAAO,EACL,iBAAiB,GAElB,MAAM,gCAAgC,CAAC;AACxC,OAAO,EAAE,aAAa,EAA2B,MAAM,4BAA4B,CAAC;AACpF,OAAO,EAAE,iBAAiB,EAA+B,MAAM,gCAAgC,CAAC;AAChG,OAAO,EAAE,YAAY,EAA0B,MAAM,2BAA2B,CAAC;AACjF,OAAO,EACL,8BAA8B,EAC9B,kBAAkB,GAEnB,MAAM,iCAAiC,CAAC;AACzC,OAAO,EAAE,UAAU,EAAwB,MAAM,yBAAyB,CAAC;AAC3E,OAAO,EAAE,YAAY,EAA0B,MAAM,2BAA2B,CAAC;AACjF,OAAO,EACL,gBAAgB,GAGjB,MAAM,+BAA+B,CAAC;AACvC,OAAO,EAAE,aAAa,EAA2B,MAAM,4BAA4B,CAAC;AACpF,OAAO,EAAE,WAAW,EAA8C,MAAM,0BAA0B,CAAC;AACnG,OAAO,EAAE,UAAU,EAAwB,MAAM,yBAAyB,CAAC;AAC3E,OAAO,EAAE,WAAW,EAAyB,MAAM,0BAA0B,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAyB,MAAM,6BAA6B,CAAC;AACjF,OAAO,EAAE,SAAS,EAAuB,MAAM,2BAA2B,CAAC;AAC3E,OAAO,EAAE,MAAM,EAAoB,MAAM,wBAAwB,CAAC;AAClE,OAAO,EAAE,UAAU,EAAwB,MAAM,4BAA4B,CAAC;AAC9E,OAAO,EAAE,iBAAiB,EAA+B,MAAM,mCAAmC,CAAC;AACnG,OAAO,EACL,cAAc,GAEf,MAAM,gCAAgC,CAAC;AACxC,OAAO,EACL,cAAc,EACd,mBAAmB,GAGpB,MAAM,gCAAgC,CAAC;AACxC,OAAO,EACL,eAAe,GAGhB,MAAM,iCAAiC,CAAC;AACzC,OAAO,EACL,eAAe,GAEhB,MAAM,iCAAiC,CAAC;AACzC,OAAO,EACL,iBAAiB,GAElB,MAAM,mCAAmC,CAAC;AAC3C,OAAO,EAAE,aAAa,EAA2B,MAAM,+BAA+B,CAAC;AACvF,OAAO,EAAE,iBAAiB,EAA+B,MAAM,mCAAmC,CAAC;AACnG,OAAO,EAAE,YAAY,EAA0B,MAAM,8BAA8B,CAAC;AACpF,OAAO,EACL,kBAAkB,EAClB,cAAc,GAGf,MAAM,gCAAgC,CAAC;AACxC,OAAO,EACL,8BAA8B,EAC9B,kBAAkB,GAEnB,MAAM,oCAAoC,CAAC;AAC5C,OAAO,EAAE,YAAY,EAA0B,MAAM,8BAA8B,CAAC;AACpF,OAAO,EAAE,UAAU,EAAwB,MAAM,4BAA4B,CAAC;AAC9E,OAAO,EAAE,YAAY,EAA0B,MAAM,8BAA8B,CAAC;AACpF,OAAO,EACL,gBAAgB,GAGjB,MAAM,kCAAkC,CAAC;AAC1C,OAAO,EAAE,aAAa,EAA2B,MAAM,+BAA+B,CAAC;AACvF,OAAO,EAAE,WAAW,EAAyB,MAAM,6BAA6B,CAAC;AACjF,OAAO,EAAE,WAAW,EAA8C,MAAM,6BAA6B,CAAC;AACtG,OAAO,EAAE,UAAU,EAAwB,MAAM,4BAA4B,CAAC;AAC9E,OAAO,EAAE,WAAW,EAAyB,MAAM,6BAA6B,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@steez-ui/ui",
3
- "version": "0.1.2",
3
+ "version": "0.1.4",
4
4
  "description": "React primitives authored with CSS modules for Steez UI.",
5
5
  "license": "MIT",
6
6
  "type": "module",
@@ -12,8 +12,8 @@
12
12
  "react-dom": ">=18"
13
13
  },
14
14
  "dependencies": {
15
- "@steez-ui/icons": "^0.1.2",
16
- "@steez-ui/theme": "^0.1.2"
15
+ "@steez-ui/icons": "^0.1.4",
16
+ "@steez-ui/theme": "^0.1.4"
17
17
  },
18
18
  "exports": {
19
19
  ".": {