summaryrefslogtreecommitdiffhomepage
path: root/packages/ui/src/components
diff options
context:
space:
mode:
authorAdam <[email protected]>2025-10-28 15:29:11 -0500
committerAdam <[email protected]>2025-10-28 15:29:16 -0500
commit545f34584847e3216ecf95ab493dacac282ec465 (patch)
tree9bf9c1e8cd2d49ee63a155e4b4131b4e1960fc0f /packages/ui/src/components
parent77ae0b527e4b1a8277b0391d0acbc7d82b08e4ea (diff)
downloadopencode-545f34584847e3216ecf95ab493dacac282ec465.tar.gz
opencode-545f34584847e3216ecf95ab493dacac282ec465.zip
wip: desktop work
Diffstat (limited to 'packages/ui/src/components')
-rw-r--r--packages/ui/src/components/collapsible.css21
-rw-r--r--packages/ui/src/components/collapsible.tsx4
2 files changed, 24 insertions, 1 deletions
diff --git a/packages/ui/src/components/collapsible.css b/packages/ui/src/components/collapsible.css
index 34699fc20..3d8c8ebea 100644
--- a/packages/ui/src/components/collapsible.css
+++ b/packages/ui/src/components/collapsible.css
@@ -57,6 +57,27 @@
/* animation: slideDown 250ms ease-out; */
/* } */
}
+
+ &[data-variant="ghost"] {
+ background-color: transparent;
+ border: none;
+
+ > [data-slot="collapsible-trigger"] {
+ background-color: transparent;
+ border: none;
+ padding: 0;
+
+ /* &:hover { */
+ /* color: var(--text-strong); */
+ /* } */
+ &:focus-visible {
+ outline: none;
+ }
+ &[data-disabled] {
+ cursor: not-allowed;
+ }
+ }
+ }
}
@keyframes slideDown {
diff --git a/packages/ui/src/components/collapsible.tsx b/packages/ui/src/components/collapsible.tsx
index d2e4a139b..17fad0b9e 100644
--- a/packages/ui/src/components/collapsible.tsx
+++ b/packages/ui/src/components/collapsible.tsx
@@ -5,13 +5,15 @@ import { Icon } from "./icon"
export interface CollapsibleProps extends ParentProps<CollapsibleRootProps> {
class?: string
classList?: ComponentProps<"div">["classList"]
+ variant?: "normal" | "ghost"
}
function CollapsibleRoot(props: CollapsibleProps) {
- const [local, others] = splitProps(props, ["class", "classList"])
+ const [local, others] = splitProps(props, ["class", "classList", "variant"])
return (
<Kobalte
data-component="collapsible"
+ data-variant={local.variant || "normal"}
classList={{
...(local.classList ?? {}),
[local.class ?? ""]: !!local.class,