@versini/ui-togglegroup 6.0.0 → 6.0.2

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.
@@ -2,7 +2,7 @@ import { JSX } from 'react/jsx-runtime';
2
2
  import type { ToggleGroupItemProps } from './ToggleGroupTypes';
3
3
  import type { ToggleGroupProps } from './ToggleGroupTypes';
4
4
 
5
- export declare const ToggleGroup: ({ children, value, onValueChange, disabled, focusMode, size, defaultValue, className, ...otherProps }: ToggleGroupProps) => JSX.Element;
5
+ export declare const ToggleGroup: ({ children, value, onValueChange, disabled, size, defaultValue, className, ...otherProps }: ToggleGroupProps) => JSX.Element;
6
6
 
7
7
  export declare const TOGGLEGROUP_CLASSNAME = "av-togglegroup";
8
8
 
@@ -1,5 +1,5 @@
1
1
  /*!
2
- @versini/ui-togglegroup v6.0.0
2
+ @versini/ui-togglegroup v6.0.2
3
3
  © 2026 gizmette.com
4
4
  */
5
5
 
@@ -17,46 +17,47 @@ const TOGGLEGROUP_ITEM_CLASSNAME = "av-togglegroup-item";
17
17
 
18
18
 
19
19
  const ToggleGroupContext = react.createContext({
20
- size: "medium",
21
- focusMode: "system"
20
+ size: "medium"
22
21
  });
23
22
 
24
23
 
25
24
 
26
25
 
27
- const getToggleGroupItemFocusClasses = ({ focusMode })=>{
28
- return clsx("focus:outline-none", "focus:ring-2", "focus:ring-inset", {
29
- "focus:ring-focus-light": focusMode === "light",
30
- "focus:ring-focus-dark": focusMode === "dark",
31
- "focus:ring-focus-light dark:focus:ring-focus-dark": focusMode === "alt-system",
32
- "focus:ring-focus-dark dark:focus:ring-focus-light": focusMode === "system"
33
- });
26
+ const getToggleGroupItemFocusClasses = ()=>{
27
+ return clsx("focus:outline-none", "focus:ring-2", "focus:ring-inset", "focus:ring-focus-dark");
34
28
  };
35
29
  const getToggleGroupItemActiveClasses = ()=>{
36
- return clsx("data-[state=on]:bg-surface-lightest data-[state=on]:text-copy-dark dark:data-[state=on]:bg-surface-dark dark:data-[state=on]:text-copy-light");
30
+ return clsx("data-[state=on]:bg-surface-lightest data-[state=on]:text-copy-dark", "dark:data-[state=on]:bg-surface-dark dark:data-[state=on]:text-copy-light");
37
31
  };
38
32
  const getToggleGroupItemSizeClasses = ({ size })=>{
39
33
  return clsx({
40
- "h-5 px-2": size === "small",
41
- "h-6 px-3": size === "medium",
42
- "h-7 px-4": size === "large"
34
+ "h-full px-1 sm:px-2": size === "small",
35
+ "h-full px-3": size === "medium",
36
+ "h-full px-4": size === "large"
37
+ });
38
+ };
39
+ const getToggleGroupSizeClasses = ({ size })=>{
40
+ return clsx({
41
+ "h-6": size === "small",
42
+ "h-8": size === "medium",
43
+ "h-12": size === "large"
43
44
  });
44
45
  };
45
46
  const getToggleGroupItemWrapperClasses = ()=>{
46
47
  return clsx(TOGGLEGROUP_ITEM_WRAPPER_CLASSNAME, "relative", "[&>button]:rounded-none", "first:[&>button]:rounded-l-md", "last:[&>button]:rounded-r-md", "border-r border-border-medium last:border-r-0");
47
48
  };
48
- const getToggleGroupItemClasses = ({ focusMode, size })=>{
49
+ const getToggleGroupItemClasses = ({ size })=>{
49
50
  return {
50
51
  wrapperClass: getToggleGroupItemWrapperClasses(),
51
- itemClass: clsx(TOGGLEGROUP_ITEM_CLASSNAME, "flex items-center justify-center bg-transparent", "transition duration-200 ease", getToggleGroupItemSizeClasses({
52
+ itemClass: clsx(TOGGLEGROUP_ITEM_CLASSNAME, "text-sm cursor-pointer", "flex items-center justify-center bg-transparent", "transition duration-200 ease", getToggleGroupItemSizeClasses({
52
53
  size
53
- }), getToggleGroupItemFocusClasses({
54
- focusMode
55
- }), getToggleGroupItemActiveClasses())
54
+ }), getToggleGroupItemFocusClasses(), getToggleGroupItemActiveClasses())
56
55
  };
57
56
  };
58
- const getToggleGroupClasses = ({ className })=>{
59
- return clsx(TOGGLEGROUP_CLASSNAME, "inline-flex", "rounded-md", "border border-border-medium", "bg-surface-light text-copy-dark/70", className);
57
+ const getToggleGroupClasses = ({ className, size })=>{
58
+ return clsx(TOGGLEGROUP_CLASSNAME, "inline-flex", "rounded-md", "border border-border-medium", "bg-surface-light text-copy-dark/70", getToggleGroupSizeClasses({
59
+ size
60
+ }), className);
60
61
  };
61
62
 
62
63
 
@@ -64,13 +65,13 @@ const getToggleGroupClasses = ({ className })=>{
64
65
 
65
66
 
66
67
 
67
- const ToggleGroup = ({ children, value, onValueChange, disabled, focusMode = "system", size = "medium", defaultValue, className, ...otherProps })=>{
68
+ const ToggleGroup = ({ children, value, onValueChange, disabled, size = "medium", defaultValue, className, ...otherProps })=>{
68
69
  const toggleGroupClasses = getToggleGroupClasses({
69
- className
70
+ className,
71
+ size
70
72
  });
71
73
  const contextValue = {
72
- size,
73
- focusMode
74
+ size
74
75
  };
75
76
  return /*#__PURE__*/ jsx(ToggleGroupContext.Provider, {
76
77
  value: contextValue,
@@ -87,9 +88,8 @@ const ToggleGroup = ({ children, value, onValueChange, disabled, focusMode = "sy
87
88
  });
88
89
  };
89
90
  const ToggleGroupItem = ({ value, disabled, children })=>{
90
- const { size, focusMode } = useContext(ToggleGroupContext);
91
+ const { size } = useContext(ToggleGroupContext);
91
92
  const { itemClass, wrapperClass } = getToggleGroupItemClasses({
92
- focusMode,
93
93
  size
94
94
  });
95
95
  return /*#__PURE__*/ jsx("div", {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@versini/ui-togglegroup",
3
- "version": "6.0.0",
3
+ "version": "6.0.2",
4
4
  "license": "MIT",
5
5
  "author": "Arno Versini",
6
6
  "publishConfig": {
@@ -47,5 +47,5 @@
47
47
  "sideEffects": [
48
48
  "**/*.css"
49
49
  ],
50
- "gitHead": "3534e50d79273f5731868c07f114faeb0ff04bf5"
50
+ "gitHead": "1c5ed3b2e06d6ba847cd311955e18faba8888d7d"
51
51
  }