@jamsrui/icon-button 0.0.9 → 0.0.11

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.
@@ -0,0 +1 @@
1
+ import{allColors as i,allVariants as t,colorVariants as e,radiusBaseVariant as n,tv as s}from"@jamsrui/utils";var d=s({base:["z-0","cursor-default","shrink-0","group","relative","inline-flex","items-center","justify-center","box-border","appearance-none","outline-none","select-none","whitespace-nowrap","min-w-max","font-medium","tap-highlight-transparent","transition-transform duration-300","focus-visible:ring-2 focus-visible:ring-primary","data-disabled:cursor-not-allowed data-disabled:opacity-60","text-transform-inherit"],variants:{color:{default:"",primary:"",secondary:"",success:"",warning:"",danger:""},variant:{solid:"",bordered:"border bg-transparent",light:"",text:"",flat:""},size:{xs:"size-6 rounded",sm:"size-8 min-w-8 rounded-lg",md:"size-10 min-w-10 rounded-xl",lg:"size-12 min-w-12 rounded-2xl"},disableAnimation:{true:"transition-none!",false:"data-pressed:scale-98"},radius:n},compoundVariants:[...t.flatMap(a=>i.map(r=>({variant:a,color:r,className:e[a][r]})))],defaultVariants:{variant:"solid",color:"default",size:"md",radius:"md",disableAnimation:!1}});export{d as a};
@@ -0,0 +1 @@
1
+ import{a as t}from"./chunk-BK47RZ6L.mjs";import{useRenderElement as p}from"@jamsrui/hooks";import{Fragment as d,jsx as u,jsxs as m}from"react/jsx-runtime";var I=o=>{let{children:n}=o,e=t(o),{getButtonProps:r,getLabelProps:s}=e,c=m(d,{children:[u("span",{...s({})}),n]});return p("button",{props:[r(),{children:c}]})};export{I as a};
@@ -0,0 +1 @@
1
+ import{a as r}from"./chunk-5BXYNIKP.mjs";import{useCallback as b,useId as x,useMemo as R}from"react";import{useHover as V,useMergeRefs as h,usePress as C}from"@jamsrui/hooks";import{cn as L,dataAttr as e,dataAttrDev as N,mapPropsVariants as A}from"@jamsrui/utils";var k=P=>{let[f,y]=A(P,r.variantKeys),{type:a="button",label:G,isDisabled:I=!1,isLoading:t=!1,disabled:B=!1,className:n,ref:g,...i}=f,p=r(y),s=x(),o=I||t||B,{isHovered:l,ref:v}=V({isDisabled:o}),{isPressed:d,ref:D}=C({isDisabled:o}),c=h([g,v,D]),m=b(()=>({...i,ref:c,"data-component":N("icon-button"),className:L(p,n),"aria-labelledby":s,type:a,disabled:o,"data-disabled":e(o),"aria-disabled":e(o),"data-loading":e(t),"data-pressed":e(d),"data-hover":e(l)}),[n,s,o,l,t,d,c,i,p,a]),u=b(()=>({"aria-hidden":!0,id:s,className:"sr-only"}),[s]);return R(()=>({getButtonProps:m,getLabelProps:u,isLoading:t,isDisabled:o}),[m,u,o,t])};export{k as a};
@@ -0,0 +1 @@
1
+ import{createConfigContext as o}from"@jamsrui/utils";var[n,r]=o({displayName:"IconButtonConfig"});export{n as a,r as b};
@@ -5,8 +5,8 @@ import { IconButtonVariantProps } from './styles.mjs';
5
5
  declare const useIconButton: (props: useIconButton.Props) => {
6
6
  getButtonProps: () => Partial<IconButton.Props>;
7
7
  getLabelProps: PropGetter<react.DetailedHTMLProps<react.HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>>;
8
- isLoading: boolean | undefined;
9
- isDisabled: boolean | undefined;
8
+ isLoading: boolean;
9
+ isDisabled: boolean;
10
10
  };
11
11
  declare namespace useIconButton {
12
12
  interface Props extends IconButtonVariantProps, UIProps<"button"> {
@@ -1,4 +1,4 @@
1
- import { I as IconButton } from './icon-button-TZJ8FKLc.mjs';
1
+ import { I as IconButton } from './icon-button-CNSWjtbn.mjs';
2
2
  import * as react_jsx_runtime from 'react/jsx-runtime';
3
3
  import { GlobalConfigProps } from '@jamsrui/core';
4
4
  import 'react';
@@ -1 +1 @@
1
- import{createConfigContext as o}from"@jamsrui/utils";const[n,r]=o({displayName:"IconButtonConfig"});export{n as IconButtonConfig,r as useIconButtonConfig};
1
+ import{a,b}from"./chunk-WOIOR7OF.mjs";export{a as IconButtonConfig,b as useIconButtonConfig};
@@ -1,4 +1,4 @@
1
1
  import 'react';
2
- export { I as IconButton } from './icon-button-TZJ8FKLc.mjs';
2
+ export { I as IconButton } from './icon-button-CNSWjtbn.mjs';
3
3
  import '@jamsrui/utils';
4
4
  import './styles.mjs';
@@ -1 +1 @@
1
- import{Fragment as d,jsx as u,jsxs as m}from"react/jsx-runtime";import{useRenderElement as c}from"@jamsrui/hooks";import{useIconButton as p}from"./use-icon-button";const I=o=>{const{children:t}=o,n=p(o),{getButtonProps:e,getLabelProps:r}=n,s=m(d,{children:[u("span",{...r({})}),t]});return c("button",{props:[e(),{children:s}]})};export{I as IconButton};
1
+ import{a}from"./chunk-67ROXZH3.mjs";import"./chunk-BK47RZ6L.mjs";import"./chunk-5BXYNIKP.mjs";export{a as IconButton};
package/dist/index.d.mts CHANGED
@@ -1,4 +1,4 @@
1
- export { I as IconButton } from './icon-button-TZJ8FKLc.mjs';
1
+ export { I as IconButton } from './icon-button-CNSWjtbn.mjs';
2
2
  export { IconButtonConfig, useIconButtonConfig } from './icon-button-config.mjs';
3
3
  import 'react';
4
4
  import '@jamsrui/utils';
package/dist/index.mjs CHANGED
@@ -1 +1 @@
1
- "use client";import{IconButton as t}from"./icon-button";import{IconButtonConfig as u,useIconButtonConfig as c}from"./icon-button-config";export{t as IconButton,u as IconButtonConfig,c as useIconButtonConfig};
1
+ "use client";import{a as o,b as n}from"./chunk-WOIOR7OF.mjs";import{a as t}from"./chunk-67ROXZH3.mjs";import"./chunk-BK47RZ6L.mjs";import"./chunk-5BXYNIKP.mjs";export{t as IconButton,o as IconButtonConfig,n as useIconButtonConfig};
package/dist/styles.mjs CHANGED
@@ -1 +1 @@
1
- import{allColors as i,allVariants as e,colorVariants as n,radiusBaseVariant as t,tv as s}from"@jamsrui/utils";const l=s({base:["z-0","cursor-pointer","shrink-0","group","relative","inline-flex","items-center","justify-center","box-border","appearance-none","outline-none","select-none","whitespace-nowrap","min-w-max","font-medium","tap-highlight-transparent","transition-transform","focus-visible:ring-2 focus-visible:ring-primary","ui-disabled:cursor-not-allowed ui-disabled:opacity-60","text-transform-inherit"],variants:{color:{default:"",primary:"",secondary:"",success:"",warning:"",danger:""},variant:{solid:"",bordered:"border-2 bg-transparent",light:"",text:"",flat:""},size:{xs:"size-6 rounded",sm:"size-8 min-w-8 rounded-lg",md:"size-10 min-w-10 rounded-xl",lg:"size-12 min-w-12 rounded-2xl"},disableAnimation:{true:"!transition-none",false:"data-[pressed=true]:scale-[0.97]"},radius:t},compoundVariants:[...e.flatMap(a=>i.map(r=>({variant:a,color:r,className:n[a][r]})))],defaultVariants:{variant:"solid",color:"default",size:"md",radius:"md",disableAnimation:!1}});export{l as iconButtonVariants};
1
+ import{a}from"./chunk-5BXYNIKP.mjs";export{a as iconButtonVariants};
@@ -1,4 +1,4 @@
1
1
  import 'react';
2
2
  import '@jamsrui/utils';
3
- export { u as useIconButton } from './icon-button-TZJ8FKLc.mjs';
3
+ export { u as useIconButton } from './icon-button-CNSWjtbn.mjs';
4
4
  import './styles.mjs';
@@ -1 +1 @@
1
- import{useCallback as c,useId as I,useMemo as B}from"react";import{cn as f,dataAttrDev as g,mapPropsVariants as D}from"@jamsrui/utils";import{iconButtonVariants as m}from"./styles";const C=u=>{const[d,b]=D(u,m.variantKeys),{type:a="button",label:r,isDisabled:P,isLoading:s,disabled:y,className:e,...n}=d,i=m(b),t=I(),o=P??s??y,p=c(()=>({...n,"data-component":g("icon-button"),className:f(i,e),"aria-label":r,"aria-labelledby":t,type:a,disabled:o,"data-disabled":o,"aria-disabled":o}),[e,t,o,r,n,i,a]),l=c(()=>({"aria-hidden":!0,id:t,className:"sr-only"}),[t]);return B(()=>({getButtonProps:p,getLabelProps:l,isLoading:s,isDisabled:o}),[p,l,o,s])};export{C as useIconButton};
1
+ import{a}from"./chunk-BK47RZ6L.mjs";import"./chunk-5BXYNIKP.mjs";export{a as useIconButton};
package/package.json CHANGED
@@ -1,19 +1,18 @@
1
1
  {
2
2
  "name": "@jamsrui/icon-button",
3
- "version": "0.0.9",
3
+ "version": "0.0.11",
4
4
  "peerDependencies": {
5
5
  "react": ">=19"
6
6
  },
7
7
  "dependencies": {
8
- "@jamsrui/hooks": "^0.0.9",
9
- "@jamsrui/core": "^0.0.8",
10
- "@jamsrui/utils": "^0.0.9"
8
+ "@jamsrui/hooks": "^0.0.11",
9
+ "@jamsrui/utils": "^0.0.11",
10
+ "@jamsrui/core": "^0.0.10"
11
11
  },
12
12
  "exports": {
13
13
  ".": {
14
14
  "types": "./dist/index.d.ts",
15
- "import": "./dist/index.mjs",
16
- "require": "./dist/index.js"
15
+ "import": "./dist/index.mjs"
17
16
  }
18
17
  },
19
18
  "description": "A modern and beautiful Next.js UI components library.",