From a5389343ab54ec7de23814fd1a376720cf54bc1c Mon Sep 17 00:00:00 2001 From: Steven Straatemans Date: Tue, 5 Nov 2024 09:43:46 +0100 Subject: [PATCH] start buttongroup compoent --- .changeset/eight-birds-knock.md | 5 ++ .../src/components/Button/Button.css.ts | 8 +- .../components/ButtonGroup/ButtonGroup.css.ts | 58 ++++++++++++++ .../ButtonGroup/ButtonGroup.stories.tsx | 77 +++++++++++++++++++ .../components/ButtonGroup/ButtonGroup.tsx | 39 ++++++++++ 5 files changed, 184 insertions(+), 3 deletions(-) create mode 100644 .changeset/eight-birds-knock.md create mode 100644 packages/libs/kode-ui/src/components/ButtonGroup/ButtonGroup.css.ts create mode 100644 packages/libs/kode-ui/src/components/ButtonGroup/ButtonGroup.stories.tsx create mode 100644 packages/libs/kode-ui/src/components/ButtonGroup/ButtonGroup.tsx diff --git a/.changeset/eight-birds-knock.md b/.changeset/eight-birds-knock.md new file mode 100644 index 0000000000..64ab0b7f02 --- /dev/null +++ b/.changeset/eight-birds-knock.md @@ -0,0 +1,5 @@ +--- +'@kadena/kode-ui': minor +--- + +add buttongroup component diff --git a/packages/libs/kode-ui/src/components/Button/Button.css.ts b/packages/libs/kode-ui/src/components/Button/Button.css.ts index 43169fa34f..ca8d39383d 100644 --- a/packages/libs/kode-ui/src/components/Button/Button.css.ts +++ b/packages/libs/kode-ui/src/components/Button/Button.css.ts @@ -316,9 +316,11 @@ export const button = recipe({ }, }, outlined: { - boxShadow: `0px 0px 0px 1px ${token( - 'color.border.base.default', - )} inset`, + border: token('border.hairline'), + borderColor: token('color.border.base.default'), + // boxShadow: `0px 0px 0px 1px ${token( + // 'color.border.base.default', + // )} inset`, vars: { [backgroundColor]: 'transparent', [hoverBackgroundColor]: token('color.background.base.@hover'), diff --git a/packages/libs/kode-ui/src/components/ButtonGroup/ButtonGroup.css.ts b/packages/libs/kode-ui/src/components/ButtonGroup/ButtonGroup.css.ts new file mode 100644 index 0000000000..17c5f39000 --- /dev/null +++ b/packages/libs/kode-ui/src/components/ButtonGroup/ButtonGroup.css.ts @@ -0,0 +1,58 @@ +import { globalStyle, recipe, style, token } from './../../../styles'; + +export const buttonGroupClass = style({}); + +export const buttonGroupRecipe = recipe({ + base: {}, + variants: { + variant: { + primary: {}, + transparent: {}, + info: {}, + warning: {}, + positive: {}, + negative: {}, + outlined: {}, + }, + }, +}); + +globalStyle( + `${buttonGroupClass} button:not(:first-child):not(:last-child), ${buttonGroupClass} a:not(:first-child):not(:last-child)`, + { + borderRadius: 0, + }, +); + +globalStyle( + `${buttonGroupClass} button:first-child, ${buttonGroupClass} a:first-child`, + { + borderEndEndRadius: 0, + borderStartEndRadius: 0, + }, +); +globalStyle( + `${buttonGroupClass} button:last-child, ${buttonGroupClass} a:last-child`, + { + borderEndStartRadius: 0, + borderStartStartRadius: 0, + }, +); + +//variants +globalStyle( + `${buttonGroupClass}[data-variant="primary"] button:not(:first-child), ${buttonGroupClass}[data-variant="primary"] a:not(:first-child)`, + { + border: 0, + borderInlineStartWidth: '1px', + borderStyle: 'solid', + borderColor: 'yellow', + }, +); + +globalStyle( + `${buttonGroupClass} button:not(:last-child), ${buttonGroupClass} a:not(:last-child)`, + { + borderInlineEndWidth: '0', + }, +); diff --git a/packages/libs/kode-ui/src/components/ButtonGroup/ButtonGroup.stories.tsx b/packages/libs/kode-ui/src/components/ButtonGroup/ButtonGroup.stories.tsx new file mode 100644 index 0000000000..842371af14 --- /dev/null +++ b/packages/libs/kode-ui/src/components/ButtonGroup/ButtonGroup.stories.tsx @@ -0,0 +1,77 @@ +import { MonoChevronLeft, MonoChevronRight } from '@kadena/kode-icons'; +import type { Meta, StoryFn, StoryObj } from '@storybook/react'; +import React from 'react'; + +import { Avatar, Badge, Button, Link, Stack } from '..'; +import { getVariants } from '../../storyDecorators/getVariants'; +import { Box } from '../Layout/Box/Box'; +import type { IButtonGroupProps } from './ButtonGroup'; +import { ButtonGroup } from './ButtonGroup'; +import { buttonGroupRecipe } from './ButtonGroup.css'; + +const variants = getVariants(buttonGroupRecipe); + +const meta: Meta = { + title: 'Components/ButtonGroup', + parameters: { + controls: { + hideNoControlsWarning: true, + sort: 'requiredFirst', + }, + docs: { + description: { + component: + 'The ButtonGroup is a component that will group a set of buttons (some small style changes on the buttons). ', + }, + }, + }, + argTypes: { + onPress: { + action: 'clicked', + description: 'callback when button is clicked', + table: { + disable: true, + }, + }, + variant: { + options: variants.variant, + control: { + type: 'select', + }, + description: 'button style variant', + }, + isCompact: { + description: 'compact button style', + control: { + type: 'boolean', + }, + }, + }, +}; + +type ButtonGroupStory = StoryObj; + +export const Primary: ButtonGroupStory = { + args: { + variant: 'primary', + onPress: () => undefined, + }, + render: (props: IButtonGroupProps) => { + return ( + + + + +