@steez-ui/ui 0.1.0

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 (106) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +52 -0
  3. package/dist/components/Button.d.ts +11 -0
  4. package/dist/components/Button.d.ts.map +1 -0
  5. package/dist/components/Button.js +8 -0
  6. package/dist/components/Button.js.map +1 -0
  7. package/dist/components/CopyButton.d.ts +10 -0
  8. package/dist/components/CopyButton.d.ts.map +1 -0
  9. package/dist/components/CopyButton.js +25 -0
  10. package/dist/components/CopyButton.js.map +1 -0
  11. package/dist/components/CopyButton.module.css +30 -0
  12. package/dist/components/CornerBracketCard.d.ts +7 -0
  13. package/dist/components/CornerBracketCard.d.ts.map +1 -0
  14. package/dist/components/CornerBracketCard.js +6 -0
  15. package/dist/components/CornerBracketCard.js.map +1 -0
  16. package/dist/components/CornerBracketCard.module.css +109 -0
  17. package/dist/components/CyberpunkCheckbox.d.ts +7 -0
  18. package/dist/components/CyberpunkCheckbox.d.ts.map +1 -0
  19. package/dist/components/CyberpunkCheckbox.js +8 -0
  20. package/dist/components/CyberpunkCheckbox.js.map +1 -0
  21. package/dist/components/CyberpunkCheckbox.module.css +57 -0
  22. package/dist/components/CyberpunkInput.d.ts +9 -0
  23. package/dist/components/CyberpunkInput.d.ts.map +1 -0
  24. package/dist/components/CyberpunkInput.js +9 -0
  25. package/dist/components/CyberpunkInput.js.map +1 -0
  26. package/dist/components/CyberpunkInput.module.css +115 -0
  27. package/dist/components/CyberpunkRadio.d.ts +17 -0
  28. package/dist/components/CyberpunkRadio.d.ts.map +1 -0
  29. package/dist/components/CyberpunkRadio.js +11 -0
  30. package/dist/components/CyberpunkRadio.js.map +1 -0
  31. package/dist/components/CyberpunkRadio.module.css +64 -0
  32. package/dist/components/CyberpunkSelect.d.ts +12 -0
  33. package/dist/components/CyberpunkSelect.d.ts.map +1 -0
  34. package/dist/components/CyberpunkSelect.js +8 -0
  35. package/dist/components/CyberpunkSelect.js.map +1 -0
  36. package/dist/components/CyberpunkSelect.module.css +108 -0
  37. package/dist/components/CyberpunkSlider.d.ts +10 -0
  38. package/dist/components/CyberpunkSlider.d.ts.map +1 -0
  39. package/dist/components/CyberpunkSlider.js +9 -0
  40. package/dist/components/CyberpunkSlider.js.map +1 -0
  41. package/dist/components/CyberpunkSlider.module.css +98 -0
  42. package/dist/components/CyberpunkTextarea.d.ts +7 -0
  43. package/dist/components/CyberpunkTextarea.d.ts.map +1 -0
  44. package/dist/components/CyberpunkTextarea.js +8 -0
  45. package/dist/components/CyberpunkTextarea.js.map +1 -0
  46. package/dist/components/CyberpunkTextarea.module.css +73 -0
  47. package/dist/components/CyberpunkTile.d.ts +10 -0
  48. package/dist/components/CyberpunkTile.d.ts.map +1 -0
  49. package/dist/components/CyberpunkTile.js +6 -0
  50. package/dist/components/CyberpunkTile.js.map +1 -0
  51. package/dist/components/CyberpunkTile.module.css +133 -0
  52. package/dist/components/ErrorMessage.d.ts +11 -0
  53. package/dist/components/ErrorMessage.d.ts.map +1 -0
  54. package/dist/components/ErrorMessage.js +16 -0
  55. package/dist/components/ErrorMessage.js.map +1 -0
  56. package/dist/components/ErrorMessage.module.css +75 -0
  57. package/dist/components/LoadingProgressBar.d.ts +8 -0
  58. package/dist/components/LoadingProgressBar.d.ts.map +1 -0
  59. package/dist/components/LoadingProgressBar.js +13 -0
  60. package/dist/components/LoadingProgressBar.js.map +1 -0
  61. package/dist/components/LoadingProgressBar.module.css +42 -0
  62. package/dist/components/PageHeader.d.ts +17 -0
  63. package/dist/components/PageHeader.d.ts.map +1 -0
  64. package/dist/components/PageHeader.js +7 -0
  65. package/dist/components/PageHeader.js.map +1 -0
  66. package/dist/components/PageHeader.module.css +118 -0
  67. package/dist/components/PageTemplate.d.ts +20 -0
  68. package/dist/components/PageTemplate.d.ts.map +1 -0
  69. package/dist/components/PageTemplate.js +8 -0
  70. package/dist/components/PageTemplate.js.map +1 -0
  71. package/dist/components/PageTemplate.module.css +55 -0
  72. package/dist/components/SegmentedControl.d.ts +16 -0
  73. package/dist/components/SegmentedControl.d.ts.map +1 -0
  74. package/dist/components/SegmentedControl.js +9 -0
  75. package/dist/components/SegmentedControl.js.map +1 -0
  76. package/dist/components/SegmentedControl.module.css +51 -0
  77. package/dist/components/StatusMessage.d.ts +6 -0
  78. package/dist/components/StatusMessage.d.ts.map +1 -0
  79. package/dist/components/StatusMessage.js +7 -0
  80. package/dist/components/StatusMessage.js.map +1 -0
  81. package/dist/components/StatusMessage.module.css +60 -0
  82. package/dist/components/TabbedPanel.d.ts +23 -0
  83. package/dist/components/TabbedPanel.d.ts.map +1 -0
  84. package/dist/components/TabbedPanel.js +36 -0
  85. package/dist/components/TabbedPanel.js.map +1 -0
  86. package/dist/components/TabbedPanel.module.css +61 -0
  87. package/dist/components/ThemeToggle.d.ts +8 -0
  88. package/dist/components/ThemeToggle.d.ts.map +1 -0
  89. package/dist/components/ThemeToggle.js +22 -0
  90. package/dist/components/ThemeToggle.js.map +1 -0
  91. package/dist/components/ThemeToggle.module.css +23 -0
  92. package/dist/components/ThemedCard.d.ts +7 -0
  93. package/dist/components/ThemedCard.d.ts.map +1 -0
  94. package/dist/components/ThemedCard.js +6 -0
  95. package/dist/components/ThemedCard.js.map +1 -0
  96. package/dist/components/ThemedCard.module.css +22 -0
  97. package/dist/hooks/useStableId.d.ts +2 -0
  98. package/dist/hooks/useStableId.d.ts.map +1 -0
  99. package/dist/hooks/useStableId.js +6 -0
  100. package/dist/hooks/useStableId.js.map +1 -0
  101. package/dist/index.d.ts +20 -0
  102. package/dist/index.d.ts.map +1 -0
  103. package/dist/index.js +20 -0
  104. package/dist/index.js.map +1 -0
  105. package/dist/styles/Buttons.module.css +96 -0
  106. package/package.json +35 -0
@@ -0,0 +1,22 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { useEffect, useState } from "react";
3
+ import { MoonIcon, SunIcon } from "@steez-ui/icons";
4
+ import styles from "./ThemeToggle.module.css";
5
+ export function ThemeToggle({ storageKey = "theme", defaultTheme = "dark", className = "", onThemeChange, }) {
6
+ const [theme, setTheme] = useState(defaultTheme);
7
+ useEffect(() => {
8
+ const savedTheme = window.localStorage.getItem(storageKey);
9
+ const initialTheme = savedTheme || defaultTheme;
10
+ setTheme(initialTheme);
11
+ document.documentElement.setAttribute("data-theme", initialTheme);
12
+ }, [defaultTheme, storageKey]);
13
+ const toggleTheme = () => {
14
+ const newTheme = theme === "dark" ? "light" : "dark";
15
+ setTheme(newTheme);
16
+ window.localStorage.setItem(storageKey, newTheme);
17
+ document.documentElement.setAttribute("data-theme", newTheme);
18
+ onThemeChange?.(newTheme);
19
+ };
20
+ return (_jsx("button", { type: "button", className: `${styles.themeToggle} ${styles.iconButton} ${className}`.trim(), onClick: toggleTheme, "aria-label": `Switch to ${theme === "dark" ? "light" : "dark"} mode`, title: `Switch to ${theme === "dark" ? "light" : "dark"} mode`, children: theme === "dark" ? _jsx(SunIcon, { width: 14, height: 14 }) : _jsx(MoonIcon, { width: 14, height: 14 }) }));
21
+ }
22
+ //# sourceMappingURL=ThemeToggle.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ThemeToggle.js","sourceRoot":"","sources":["../../src/components/ThemeToggle.tsx"],"names":[],"mappings":";AAAA,OAAc,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAEnD,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAEpD,OAAO,MAAM,MAAM,0BAA0B,CAAC;AAS9C,MAAM,UAAU,WAAW,CAAC,EAC1B,UAAU,GAAG,OAAO,EACpB,YAAY,GAAG,MAAM,EACrB,SAAS,GAAG,EAAE,EACd,aAAa,GACI;IACjB,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAmB,YAAY,CAAC,CAAC;IAEnE,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,UAAU,GAAG,MAAM,CAAC,YAAY,CAAC,OAAO,CAAC,UAAU,CAA4B,CAAC;QACtF,MAAM,YAAY,GAAG,UAAU,IAAI,YAAY,CAAC;QAChD,QAAQ,CAAC,YAAY,CAAC,CAAC;QACvB,QAAQ,CAAC,eAAe,CAAC,YAAY,CAAC,YAAY,EAAE,YAAY,CAAC,CAAC;IACpE,CAAC,EAAE,CAAC,YAAY,EAAE,UAAU,CAAC,CAAC,CAAC;IAE/B,MAAM,WAAW,GAAG,GAAG,EAAE;QACvB,MAAM,QAAQ,GAAG,KAAK,KAAK,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC;QACrD,QAAQ,CAAC,QAAQ,CAAC,CAAC;QACnB,MAAM,CAAC,YAAY,CAAC,OAAO,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC;QAClD,QAAQ,CAAC,eAAe,CAAC,YAAY,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAC;QAC9D,aAAa,EAAE,CAAC,QAAQ,CAAC,CAAC;IAC5B,CAAC,CAAC;IAEF,OAAO,CACL,iBACE,IAAI,EAAC,QAAQ,EACb,SAAS,EAAE,GAAG,MAAM,CAAC,WAAW,IAAI,MAAM,CAAC,UAAU,IAAI,SAAS,EAAE,CAAC,IAAI,EAAE,EAC3E,OAAO,EAAE,WAAW,gBACR,aAAa,KAAK,KAAK,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,OAAO,EACnE,KAAK,EAAE,aAAa,KAAK,KAAK,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,OAAO,YAE7D,KAAK,KAAK,MAAM,CAAC,CAAC,CAAC,KAAC,OAAO,IAAC,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,GAAI,CAAC,CAAC,CAAC,KAAC,QAAQ,IAAC,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,GAAI,GACrF,CACV,CAAC;AACJ,CAAC"}
@@ -0,0 +1,23 @@
1
+ .themeToggle {
2
+ border: 1px solid var(--border-color);
3
+ background: color-mix(in srgb, var(--bg-secondary) 85%, transparent);
4
+ color: var(--text-primary);
5
+ border-radius: 999px;
6
+ padding: 0.5rem;
7
+ display: inline-flex;
8
+ align-items: center;
9
+ justify-content: center;
10
+ cursor: pointer;
11
+ transition: all var(--transition-fast);
12
+ }
13
+
14
+ .themeToggle:hover {
15
+ border-color: var(--interactive-secondary-border-hover);
16
+ background: var(--interactive-secondary-bg-hover);
17
+ }
18
+
19
+ .iconButton {
20
+ width: 2.25rem;
21
+ height: 2.25rem;
22
+ }
23
+
@@ -0,0 +1,7 @@
1
+ import React from "react";
2
+ export interface ThemedCardProps extends Omit<React.HTMLAttributes<HTMLDivElement>, "title"> {
3
+ title?: React.ReactNode;
4
+ variant?: "default" | "featured";
5
+ }
6
+ export declare function ThemedCard({ title, variant, className, children, ...props }: ThemedCardProps): import("react/jsx-runtime").JSX.Element;
7
+ //# sourceMappingURL=ThemedCard.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ThemedCard.d.ts","sourceRoot":"","sources":["../../src/components/ThemedCard.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,MAAM,WAAW,eACf,SAAQ,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,cAAc,CAAC,EAAE,OAAO,CAAC;IAC3D,KAAK,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACxB,OAAO,CAAC,EAAE,SAAS,GAAG,UAAU,CAAC;CAClC;AAED,wBAAgB,UAAU,CAAC,EACzB,KAAK,EACL,OAAmB,EACnB,SAAc,EACd,QAAQ,EACR,GAAG,KAAK,EACT,EAAE,eAAe,2CAOjB"}
@@ -0,0 +1,6 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import styles from "./ThemedCard.module.css";
3
+ export function ThemedCard({ title, variant = "default", className = "", children, ...props }) {
4
+ return (_jsxs("div", { className: `${styles.card} ${variant === "featured" ? styles.featured : ""} ${className}`.trim(), ...props, children: [title ? _jsx("div", { className: styles.title, children: title }) : null, children] }));
5
+ }
6
+ //# sourceMappingURL=ThemedCard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ThemedCard.js","sourceRoot":"","sources":["../../src/components/ThemedCard.tsx"],"names":[],"mappings":";AAEA,OAAO,MAAM,MAAM,yBAAyB,CAAC;AAQ7C,MAAM,UAAU,UAAU,CAAC,EACzB,KAAK,EACL,OAAO,GAAG,SAAS,EACnB,SAAS,GAAG,EAAE,EACd,QAAQ,EACR,GAAG,KAAK,EACQ;IAChB,OAAO,CACL,eAAK,SAAS,EAAE,GAAG,MAAM,CAAC,IAAI,IAAI,OAAO,KAAK,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,IAAI,SAAS,EAAE,CAAC,IAAI,EAAE,KAAM,KAAK,aAC7G,KAAK,CAAC,CAAC,CAAC,cAAK,SAAS,EAAE,MAAM,CAAC,KAAK,YAAG,KAAK,GAAO,CAAC,CAAC,CAAC,IAAI,EAC1D,QAAQ,IACL,CACP,CAAC;AACJ,CAAC"}
@@ -0,0 +1,22 @@
1
+ .card {
2
+ position: relative;
3
+ border: 1px solid var(--border-color);
4
+ background: color-mix(in srgb, var(--bg-secondary) 88%, transparent);
5
+ border-radius: 14px;
6
+ padding: 1rem;
7
+ box-shadow: var(--shadow-sm);
8
+ }
9
+
10
+ .featured {
11
+ border-color: var(--accent-primary);
12
+ box-shadow: var(--shadow-md);
13
+ }
14
+
15
+ .title {
16
+ margin-bottom: 0.75rem;
17
+ color: var(--text-primary);
18
+ font-family: var(--font-primary);
19
+ font-size: 1rem;
20
+ font-weight: 600;
21
+ }
22
+
@@ -0,0 +1,2 @@
1
+ export declare function useStableId(prefix: string, explicitId?: string): string;
2
+ //# sourceMappingURL=useStableId.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useStableId.d.ts","sourceRoot":"","sources":["../../src/hooks/useStableId.ts"],"names":[],"mappings":"AAEA,wBAAgB,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,MAAM,CAGvE"}
@@ -0,0 +1,6 @@
1
+ import { useId } from "react";
2
+ export function useStableId(prefix, explicitId) {
3
+ const reactId = useId().replace(/:/g, "");
4
+ return explicitId || `${prefix}-${reactId}`;
5
+ }
6
+ //# sourceMappingURL=useStableId.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useStableId.js","sourceRoot":"","sources":["../../src/hooks/useStableId.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,OAAO,CAAC;AAE9B,MAAM,UAAU,WAAW,CAAC,MAAc,EAAE,UAAmB;IAC7D,MAAM,OAAO,GAAG,KAAK,EAAE,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;IAC1C,OAAO,UAAU,IAAI,GAAG,MAAM,IAAI,OAAO,EAAE,CAAC;AAC9C,CAAC"}
@@ -0,0 +1,20 @@
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";
20
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +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"}
package/dist/index.js ADDED
@@ -0,0 +1,20 @@
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";
20
+ //# sourceMappingURL=index.js.map
@@ -0,0 +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"}
@@ -0,0 +1,96 @@
1
+ .primary {
2
+ padding: 8px 16px;
3
+ background: var(--interactive-primary-bg);
4
+ color: var(--interactive-primary-fg);
5
+ border: 1px solid var(--interactive-primary-border);
6
+ border-radius: 6px;
7
+ cursor: pointer;
8
+ transition: all var(--transition-fast);
9
+ font-family: var(--font-mono);
10
+ font-weight: 600;
11
+ font-size: 0.875rem;
12
+ }
13
+
14
+ .primary:hover:not(:disabled) {
15
+ background: var(--interactive-primary-bg-hover);
16
+ border-color: var(--interactive-primary-border);
17
+ }
18
+
19
+ .secondary {
20
+ padding: 8px 16px;
21
+ background: var(--interactive-secondary-bg);
22
+ color: var(--interactive-secondary-fg);
23
+ border: 1px solid var(--interactive-secondary-border);
24
+ border-radius: 6px;
25
+ cursor: pointer;
26
+ transition: all var(--transition-fast);
27
+ font-family: var(--font-mono);
28
+ font-weight: 600;
29
+ font-size: 0.875rem;
30
+ }
31
+
32
+ .secondary:hover:not(:disabled) {
33
+ color: var(--interactive-secondary-fg);
34
+ background: var(--interactive-secondary-bg-hover);
35
+ border-color: var(--interactive-secondary-border-hover);
36
+ }
37
+
38
+ .toolbarButton {
39
+ display: inline-flex;
40
+ align-items: center;
41
+ gap: 0.375rem;
42
+ padding: 0.5rem 0.75rem;
43
+ background: var(--interactive-secondary-bg);
44
+ color: var(--interactive-secondary-fg);
45
+ border: 1px solid var(--interactive-secondary-border);
46
+ border-radius: 4px;
47
+ cursor: pointer;
48
+ transition: all var(--transition-fast);
49
+ font-family: var(--font-mono);
50
+ font-size: 0.875rem;
51
+ font-weight: 500;
52
+ white-space: nowrap;
53
+ }
54
+
55
+ .toolbarButton:hover:not(:disabled) {
56
+ background: var(--interactive-primary-bg);
57
+ border-color: var(--interactive-primary-border);
58
+ color: var(--interactive-primary-fg);
59
+ }
60
+
61
+ .danger {
62
+ padding: 8px 16px;
63
+ background: var(--danger-bg);
64
+ color: var(--danger);
65
+ border: 1px solid var(--danger);
66
+ border-radius: 6px;
67
+ cursor: pointer;
68
+ transition: all var(--transition-fast);
69
+ font-family: var(--font-mono);
70
+ font-weight: 600;
71
+ font-size: 0.875rem;
72
+ }
73
+
74
+ .danger:hover:not(:disabled) {
75
+ background: var(--danger);
76
+ color: var(--text-on-accent);
77
+ }
78
+
79
+ .small {
80
+ padding: 4px 10px;
81
+ font-size: 0.75rem;
82
+ }
83
+
84
+ .large {
85
+ padding: 12px 24px;
86
+ font-size: 1rem;
87
+ }
88
+
89
+ .primary:disabled,
90
+ .secondary:disabled,
91
+ .toolbarButton:disabled,
92
+ .danger:disabled {
93
+ opacity: 0.5;
94
+ cursor: not-allowed;
95
+ }
96
+
package/package.json ADDED
@@ -0,0 +1,35 @@
1
+ {
2
+ "name": "@steez-ui/ui",
3
+ "version": "0.1.0",
4
+ "license": "MIT",
5
+ "type": "module",
6
+ "files": [
7
+ "dist"
8
+ ],
9
+ "peerDependencies": {
10
+ "react": ">=18",
11
+ "react-dom": ">=18"
12
+ },
13
+ "dependencies": {
14
+ "@steez-ui/icons": "^0.1.0",
15
+ "@steez-ui/theme": "^0.1.0"
16
+ },
17
+ "exports": {
18
+ ".": {
19
+ "types": "./dist/index.d.ts",
20
+ "import": "./dist/index.js"
21
+ },
22
+ "./styles/Buttons.module.css": "./dist/styles/Buttons.module.css"
23
+ },
24
+ "publishConfig": {
25
+ "access": "public"
26
+ },
27
+ "repository": {
28
+ "type": "git",
29
+ "url": "git+https://github.com/thomasjvu/steez-ui.git"
30
+ },
31
+ "homepage": "https://steez-ui.pages.dev",
32
+ "bugs": {
33
+ "url": "https://github.com/thomasjvu/steez-ui/issues"
34
+ }
35
+ }