@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.
- package/LICENSE +21 -0
- package/README.md +52 -0
- package/dist/components/Button.d.ts +11 -0
- package/dist/components/Button.d.ts.map +1 -0
- package/dist/components/Button.js +8 -0
- package/dist/components/Button.js.map +1 -0
- package/dist/components/CopyButton.d.ts +10 -0
- package/dist/components/CopyButton.d.ts.map +1 -0
- package/dist/components/CopyButton.js +25 -0
- package/dist/components/CopyButton.js.map +1 -0
- package/dist/components/CopyButton.module.css +30 -0
- package/dist/components/CornerBracketCard.d.ts +7 -0
- package/dist/components/CornerBracketCard.d.ts.map +1 -0
- package/dist/components/CornerBracketCard.js +6 -0
- package/dist/components/CornerBracketCard.js.map +1 -0
- package/dist/components/CornerBracketCard.module.css +109 -0
- package/dist/components/CyberpunkCheckbox.d.ts +7 -0
- package/dist/components/CyberpunkCheckbox.d.ts.map +1 -0
- package/dist/components/CyberpunkCheckbox.js +8 -0
- package/dist/components/CyberpunkCheckbox.js.map +1 -0
- package/dist/components/CyberpunkCheckbox.module.css +57 -0
- package/dist/components/CyberpunkInput.d.ts +9 -0
- package/dist/components/CyberpunkInput.d.ts.map +1 -0
- package/dist/components/CyberpunkInput.js +9 -0
- package/dist/components/CyberpunkInput.js.map +1 -0
- package/dist/components/CyberpunkInput.module.css +115 -0
- package/dist/components/CyberpunkRadio.d.ts +17 -0
- package/dist/components/CyberpunkRadio.d.ts.map +1 -0
- package/dist/components/CyberpunkRadio.js +11 -0
- package/dist/components/CyberpunkRadio.js.map +1 -0
- package/dist/components/CyberpunkRadio.module.css +64 -0
- package/dist/components/CyberpunkSelect.d.ts +12 -0
- package/dist/components/CyberpunkSelect.d.ts.map +1 -0
- package/dist/components/CyberpunkSelect.js +8 -0
- package/dist/components/CyberpunkSelect.js.map +1 -0
- package/dist/components/CyberpunkSelect.module.css +108 -0
- package/dist/components/CyberpunkSlider.d.ts +10 -0
- package/dist/components/CyberpunkSlider.d.ts.map +1 -0
- package/dist/components/CyberpunkSlider.js +9 -0
- package/dist/components/CyberpunkSlider.js.map +1 -0
- package/dist/components/CyberpunkSlider.module.css +98 -0
- package/dist/components/CyberpunkTextarea.d.ts +7 -0
- package/dist/components/CyberpunkTextarea.d.ts.map +1 -0
- package/dist/components/CyberpunkTextarea.js +8 -0
- package/dist/components/CyberpunkTextarea.js.map +1 -0
- package/dist/components/CyberpunkTextarea.module.css +73 -0
- package/dist/components/CyberpunkTile.d.ts +10 -0
- package/dist/components/CyberpunkTile.d.ts.map +1 -0
- package/dist/components/CyberpunkTile.js +6 -0
- package/dist/components/CyberpunkTile.js.map +1 -0
- package/dist/components/CyberpunkTile.module.css +133 -0
- package/dist/components/ErrorMessage.d.ts +11 -0
- package/dist/components/ErrorMessage.d.ts.map +1 -0
- package/dist/components/ErrorMessage.js +16 -0
- package/dist/components/ErrorMessage.js.map +1 -0
- package/dist/components/ErrorMessage.module.css +75 -0
- package/dist/components/LoadingProgressBar.d.ts +8 -0
- package/dist/components/LoadingProgressBar.d.ts.map +1 -0
- package/dist/components/LoadingProgressBar.js +13 -0
- package/dist/components/LoadingProgressBar.js.map +1 -0
- package/dist/components/LoadingProgressBar.module.css +42 -0
- package/dist/components/PageHeader.d.ts +17 -0
- package/dist/components/PageHeader.d.ts.map +1 -0
- package/dist/components/PageHeader.js +7 -0
- package/dist/components/PageHeader.js.map +1 -0
- package/dist/components/PageHeader.module.css +118 -0
- package/dist/components/PageTemplate.d.ts +20 -0
- package/dist/components/PageTemplate.d.ts.map +1 -0
- package/dist/components/PageTemplate.js +8 -0
- package/dist/components/PageTemplate.js.map +1 -0
- package/dist/components/PageTemplate.module.css +55 -0
- package/dist/components/SegmentedControl.d.ts +16 -0
- package/dist/components/SegmentedControl.d.ts.map +1 -0
- package/dist/components/SegmentedControl.js +9 -0
- package/dist/components/SegmentedControl.js.map +1 -0
- package/dist/components/SegmentedControl.module.css +51 -0
- package/dist/components/StatusMessage.d.ts +6 -0
- package/dist/components/StatusMessage.d.ts.map +1 -0
- package/dist/components/StatusMessage.js +7 -0
- package/dist/components/StatusMessage.js.map +1 -0
- package/dist/components/StatusMessage.module.css +60 -0
- package/dist/components/TabbedPanel.d.ts +23 -0
- package/dist/components/TabbedPanel.d.ts.map +1 -0
- package/dist/components/TabbedPanel.js +36 -0
- package/dist/components/TabbedPanel.js.map +1 -0
- package/dist/components/TabbedPanel.module.css +61 -0
- package/dist/components/ThemeToggle.d.ts +8 -0
- package/dist/components/ThemeToggle.d.ts.map +1 -0
- package/dist/components/ThemeToggle.js +22 -0
- package/dist/components/ThemeToggle.js.map +1 -0
- package/dist/components/ThemeToggle.module.css +23 -0
- package/dist/components/ThemedCard.d.ts +7 -0
- package/dist/components/ThemedCard.d.ts.map +1 -0
- package/dist/components/ThemedCard.js +6 -0
- package/dist/components/ThemedCard.js.map +1 -0
- package/dist/components/ThemedCard.module.css +22 -0
- package/dist/hooks/useStableId.d.ts +2 -0
- package/dist/hooks/useStableId.d.ts.map +1 -0
- package/dist/hooks/useStableId.js +6 -0
- package/dist/hooks/useStableId.js.map +1 -0
- package/dist/index.d.ts +20 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +20 -0
- package/dist/index.js.map +1 -0
- package/dist/styles/Buttons.module.css +96 -0
- 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 @@
|
|
|
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 @@
|
|
|
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"}
|
package/dist/index.d.ts
ADDED
|
@@ -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
|
+
}
|