@pandacss/studio 0.28.0 → 0.29.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.
Files changed (38) hide show
  1. package/dist/studio.js +6 -3
  2. package/dist/studio.mjs +6 -3
  3. package/package.json +8 -8
  4. package/styled-system/css/conditions.mjs +1 -1
  5. package/styled-system/css/css.mjs +1 -1
  6. package/styled-system/helpers.mjs +31 -1
  7. package/styled-system/jsx/cq.d.ts +10 -0
  8. package/styled-system/jsx/cq.mjs +14 -0
  9. package/styled-system/jsx/index.d.ts +1 -0
  10. package/styled-system/jsx/index.mjs +2 -1
  11. package/styled-system/jsx/is-valid-prop.mjs +1 -1
  12. package/styled-system/patterns/aspect-ratio.mjs +5 -2
  13. package/styled-system/patterns/bleed.mjs +12 -7
  14. package/styled-system/patterns/box.mjs +5 -2
  15. package/styled-system/patterns/center.mjs +5 -2
  16. package/styled-system/patterns/circle.mjs +5 -2
  17. package/styled-system/patterns/container.mjs +5 -2
  18. package/styled-system/patterns/cq.d.ts +22 -0
  19. package/styled-system/patterns/cq.mjs +21 -0
  20. package/styled-system/patterns/divider.mjs +8 -4
  21. package/styled-system/patterns/flex.mjs +5 -2
  22. package/styled-system/patterns/float.mjs +10 -3
  23. package/styled-system/patterns/grid-item.mjs +5 -2
  24. package/styled-system/patterns/grid.mjs +11 -6
  25. package/styled-system/patterns/hstack.mjs +8 -4
  26. package/styled-system/patterns/index.d.ts +2 -1
  27. package/styled-system/patterns/index.mjs +2 -1
  28. package/styled-system/patterns/link-box.mjs +5 -2
  29. package/styled-system/patterns/link-overlay.mjs +5 -2
  30. package/styled-system/patterns/spacer.mjs +5 -2
  31. package/styled-system/patterns/square.mjs +5 -2
  32. package/styled-system/patterns/stack.mjs +8 -4
  33. package/styled-system/patterns/visually-hidden.mjs +5 -2
  34. package/styled-system/patterns/vstack.mjs +8 -4
  35. package/styled-system/patterns/wrap.mjs +5 -2
  36. package/styled-system/types/conditions.d.ts +24 -0
  37. package/styled-system/types/pattern.d.ts +13 -2
  38. package/styled-system/types/prop-type.d.ts +1 -0
package/dist/studio.js CHANGED
@@ -48,7 +48,8 @@ async function buildStudio({ outDir, configPath }) {
48
48
  await astro.build({
49
49
  outDir,
50
50
  root: appPath,
51
- integrations: [react(), studio()]
51
+ integrations: [react(), studio()],
52
+ devToolbar: { enabled: false }
52
53
  });
53
54
  } catch (error) {
54
55
  console.log(error);
@@ -67,7 +68,8 @@ async function serveStudio({ configPath, port, host, outDir }) {
67
68
  server: {
68
69
  port: port ? Number(port) : void 0,
69
70
  host
70
- }
71
+ },
72
+ devToolbar: { enabled: false }
71
73
  });
72
74
  } catch (error) {
73
75
  console.log(error);
@@ -81,7 +83,8 @@ async function previewStudio({ outDir }) {
81
83
  await astro.preview({
82
84
  outDir,
83
85
  root: appPath,
84
- integrations: [react(), studio()]
86
+ integrations: [react(), studio()],
87
+ devToolbar: { enabled: false }
85
88
  });
86
89
  } catch (error) {
87
90
  console.log(error);
package/dist/studio.mjs CHANGED
@@ -18,7 +18,8 @@ async function buildStudio({ outDir, configPath }) {
18
18
  await astro.build({
19
19
  outDir,
20
20
  root: appPath,
21
- integrations: [react(), studio()]
21
+ integrations: [react(), studio()],
22
+ devToolbar: { enabled: false }
22
23
  });
23
24
  } catch (error) {
24
25
  console.log(error);
@@ -37,7 +38,8 @@ async function serveStudio({ configPath, port, host, outDir }) {
37
38
  server: {
38
39
  port: port ? Number(port) : void 0,
39
40
  host
40
- }
41
+ },
42
+ devToolbar: { enabled: false }
41
43
  });
42
44
  } catch (error) {
43
45
  console.log(error);
@@ -51,7 +53,8 @@ async function previewStudio({ outDir }) {
51
53
  await astro.preview({
52
54
  outDir,
53
55
  root: appPath,
54
- integrations: [react(), studio()]
56
+ integrations: [react(), studio()],
57
+ devToolbar: { enabled: false }
55
58
  });
56
59
  } catch (error) {
57
60
  console.log(error);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@pandacss/studio",
3
- "version": "0.28.0",
3
+ "version": "0.29.0",
4
4
  "description": "The automated token documentation for Panda CSS",
5
5
  "main": "dist/studio.js",
6
6
  "module": "dist/studio.mjs",
@@ -44,16 +44,16 @@
44
44
  "license": "MIT",
45
45
  "dependencies": {
46
46
  "@astrojs/react": "2.3.2",
47
- "astro": "4.2.1",
47
+ "astro": "4.2.6",
48
48
  "react": "18.2.0",
49
49
  "react-dom": "18.2.0",
50
50
  "vite": "5.0.12",
51
- "@pandacss/config": "0.28.0",
52
- "@pandacss/logger": "0.28.0",
53
- "@pandacss/shared": "0.28.0",
54
- "@pandacss/token-dictionary": "0.28.0",
55
- "@pandacss/types": "0.28.0",
56
- "@pandacss/astro-plugin-studio": "0.28.0"
51
+ "@pandacss/config": "0.29.0",
52
+ "@pandacss/logger": "0.29.0",
53
+ "@pandacss/shared": "0.29.0",
54
+ "@pandacss/token-dictionary": "0.29.0",
55
+ "@pandacss/types": "0.29.0",
56
+ "@pandacss/astro-plugin-studio": "0.29.0"
57
57
  },
58
58
  "devDependencies": {
59
59
  "@types/react": "18.2.42",
@@ -1,6 +1,6 @@
1
1
  import { withoutSpace } from '../helpers.mjs';
2
2
 
3
- const conditionsStr = "_hover,_focus,_focusWithin,_focusVisible,_disabled,_active,_visited,_target,_readOnly,_readWrite,_empty,_checked,_enabled,_expanded,_highlighted,_before,_after,_firstLetter,_firstLine,_marker,_selection,_file,_backdrop,_first,_last,_only,_even,_odd,_firstOfType,_lastOfType,_onlyOfType,_peerFocus,_peerHover,_peerActive,_peerFocusWithin,_peerFocusVisible,_peerDisabled,_peerChecked,_peerInvalid,_peerExpanded,_peerPlaceholderShown,_groupFocus,_groupHover,_groupActive,_groupFocusWithin,_groupFocusVisible,_groupDisabled,_groupChecked,_groupExpanded,_groupInvalid,_indeterminate,_required,_valid,_invalid,_autofill,_inRange,_outOfRange,_placeholder,_placeholderShown,_pressed,_selected,_default,_optional,_open,_closed,_fullscreen,_loading,_currentPage,_currentStep,_motionReduce,_motionSafe,_print,_landscape,_portrait,_dark,_light,_osDark,_osLight,_highContrast,_lessContrast,_moreContrast,_ltr,_rtl,_scrollbar,_scrollbarThumb,_scrollbarTrack,_horizontal,_vertical,sm,smOnly,smDown,md,mdOnly,mdDown,lg,lgOnly,lgDown,xl,xlOnly,xlDown,2xl,2xlOnly,2xlDown,smToMd,smToLg,smToXl,smTo2xl,mdToLg,mdToXl,mdTo2xl,lgToXl,lgTo2xl,xlTo2xl,base"
3
+ const conditionsStr = "_hover,_focus,_focusWithin,_focusVisible,_disabled,_active,_visited,_target,_readOnly,_readWrite,_empty,_checked,_enabled,_expanded,_highlighted,_before,_after,_firstLetter,_firstLine,_marker,_selection,_file,_backdrop,_first,_last,_only,_even,_odd,_firstOfType,_lastOfType,_onlyOfType,_peerFocus,_peerHover,_peerActive,_peerFocusWithin,_peerFocusVisible,_peerDisabled,_peerChecked,_peerInvalid,_peerExpanded,_peerPlaceholderShown,_groupFocus,_groupHover,_groupActive,_groupFocusWithin,_groupFocusVisible,_groupDisabled,_groupChecked,_groupExpanded,_groupInvalid,_indeterminate,_required,_valid,_invalid,_autofill,_inRange,_outOfRange,_placeholder,_placeholderShown,_pressed,_selected,_default,_optional,_open,_closed,_fullscreen,_loading,_currentPage,_currentStep,_motionReduce,_motionSafe,_print,_landscape,_portrait,_dark,_light,_osDark,_osLight,_highContrast,_lessContrast,_moreContrast,_ltr,_rtl,_scrollbar,_scrollbarThumb,_scrollbarTrack,_horizontal,_vertical,sm,smOnly,smDown,md,mdOnly,mdDown,lg,lgOnly,lgDown,xl,xlOnly,xlDown,2xl,2xlOnly,2xlDown,smToMd,smToLg,smToXl,smTo2xl,mdToLg,mdToXl,mdTo2xl,lgToXl,lgTo2xl,xlTo2xl,@/xs,@/sm,@/md,@/lg,@/xl,@/2xl,@/3xl,@/4xl,@/5xl,@/6xl,@/7xl,@/8xl,base"
4
4
  const conditions = new Set(conditionsStr.split(','))
5
5
 
6
6
  export function isCondition(value){
@@ -1,7 +1,7 @@
1
1
  import { createCss, createMergeCss, hypenateProperty, withoutSpace } from '../helpers.mjs';
2
2
  import { sortConditions, finalizeConditions } from './conditions.mjs';
3
3
 
4
- const utilities = "aspectRatio:aspect,boxDecorationBreak:decoration,zIndex:z,boxSizing:box,objectPosition:object,objectFit:object,overscrollBehavior:overscroll,overscrollBehaviorX:overscroll-x,overscrollBehaviorY:overscroll-y,position:pos/1,top:top,left:left,insetInline:inset-x,insetBlock:inset-y,inset:inset,insetBlockEnd:inset-b,insetBlockStart:inset-t,insetInlineEnd:end/insetEnd/1,insetInlineStart:start/insetStart/1,right:right,bottom:bottom,insetX:inset-x,insetY:inset-y,float:float,visibility:vis,display:d,hideFrom:hide,hideBelow:show,flexBasis:basis,flex:flex,flexDirection:flex/flexDir,flexGrow:grow,flexShrink:shrink,gridTemplateColumns:grid-cols,gridTemplateRows:grid-rows,gridColumn:col-span,gridRow:row-span,gridColumnStart:col-start,gridColumnEnd:col-end,gridAutoFlow:grid-flow,gridAutoColumns:auto-cols,gridAutoRows:auto-rows,gap:gap,gridGap:gap,gridRowGap:gap-x,gridColumnGap:gap-y,rowGap:gap-x,columnGap:gap-y,justifyContent:justify,alignContent:content,alignItems:items,alignSelf:self,padding:p/1,paddingLeft:pl/1,paddingRight:pr/1,paddingTop:pt/1,paddingBottom:pb/1,paddingBlock:py/1/paddingY,paddingBlockEnd:pb,paddingBlockStart:pt,paddingInline:px/paddingX/1,paddingInlineEnd:pe/1/paddingEnd,paddingInlineStart:ps/1/paddingStart,marginLeft:ml/1,marginRight:mr/1,marginTop:mt/1,marginBottom:mb/1,margin:m/1,marginBlock:my/1/marginY,marginBlockEnd:mb,marginBlockStart:mt,marginInline:mx/1/marginX,marginInlineEnd:me/1/marginEnd,marginInlineStart:ms/1/marginStart,outlineWidth:ring/ringWidth,outlineColor:ring/ringColor,outline:ring/1,outlineOffset:ring/ringOffset,divideX:divide-x,divideY:divide-y,divideColor:divide,divideStyle:divide,width:w/1,inlineSize:w,minWidth:min-w/minW,minInlineSize:min-w,maxWidth:max-w/maxW,maxInlineSize:max-w,height:h/1,blockSize:h,minHeight:min-h/minH,minBlockSize:min-h,maxHeight:max-h/maxH,maxBlockSize:max-b,color:text,fontFamily:font,fontSize:fs,fontWeight:font,fontSmoothing:smoothing,fontVariantNumeric:numeric,letterSpacing:tracking,lineHeight:leading,textAlign:text,textDecoration:text-decor,textDecorationColor:text-decor,textEmphasisColor:text-emphasis,textDecorationStyle:decoration,textDecorationThickness:decoration,textUnderlineOffset:underline-offset,textTransform:text,textIndent:indent,textShadow:text-shadow,textOverflow:text,verticalAlign:align,wordBreak:break,textWrap:text,truncate:truncate,lineClamp:clamp,listStyleType:list,listStylePosition:list,listStyleImage:list-img,backgroundPosition:bg/bgPosition,backgroundPositionX:bg-x/bgPositionX,backgroundPositionY:bg-y/bgPositionY,backgroundAttachment:bg/bgAttachment,backgroundClip:bg-clip/bgClip,background:bg/1,backgroundColor:bg/bgColor,backgroundOrigin:bg-origin/bgOrigin,backgroundImage:bg-img/bgImage,backgroundRepeat:bg-repeat/bgRepeat,backgroundBlendMode:bg-blend/bgBlendMode,backgroundSize:bg/bgSize,backgroundGradient:bg-gradient/bgGradient,textGradient:text-gradient,gradientFrom:from,gradientTo:to,gradientVia:via,borderRadius:rounded/1,borderTopLeftRadius:rounded-tl/roundedTopLeft,borderTopRightRadius:rounded-tr/roundedTopRight,borderBottomRightRadius:rounded-br/roundedBottomRight,borderBottomLeftRadius:rounded-bl/roundedBottomLeft,borderTopRadius:rounded-t/roundedTop,borderRightRadius:rounded-r/roundedRight,borderBottomRadius:rounded-b/roundedBottom,borderLeftRadius:rounded-l/roundedLeft,borderStartStartRadius:rounded-ss/roundedStartStart,borderStartEndRadius:rounded-se/roundedStartEnd,borderStartRadius:rounded-s/roundedStart,borderEndStartRadius:rounded-es/roundedEndStart,borderEndEndRadius:rounded-ee/roundedEndEnd,borderEndRadius:rounded-e/roundedEnd,border:border,borderWidth:border-w,borderTopWidth:border-tw,borderLeftWidth:border-lw,borderRightWidth:border-rw,borderBottomWidth:border-bw,borderColor:border,borderInline:border-x/borderX,borderInlineWidth:border-x/borderXWidth,borderInlineColor:border-x/borderXColor,borderBlock:border-y/borderY,borderBlockWidth:border-y/borderYWidth,borderBlockColor:border-y/borderYColor,borderLeft:border-l,borderLeftColor:border-l,borderInlineStart:border-s/borderStart,borderInlineStartWidth:border-s/borderStartWidth,borderInlineStartColor:border-s/borderStartColor,borderRight:border-r,borderRightColor:border-r,borderInlineEnd:border-e/borderEnd,borderInlineEndWidth:border-e/borderEndWidth,borderInlineEndColor:border-e/borderEndColor,borderTop:border-t,borderTopColor:border-t,borderBottom:border-b,borderBottomColor:border-b,borderBlockEnd:border-be,borderBlockEndColor:border-be,borderBlockStart:border-bs,borderBlockStartColor:border-bs,boxShadow:shadow/1,boxShadowColor:shadow/shadowColor,mixBlendMode:mix-blend,filter:filter,brightness:brightness,contrast:contrast,grayscale:grayscale,hueRotate:hue-rotate,invert:invert,saturate:saturate,sepia:sepia,dropShadow:drop-shadow,blur:blur,backdropFilter:backdrop,backdropBlur:backdrop-blur,backdropBrightness:backdrop-brightness,backdropContrast:backdrop-contrast,backdropGrayscale:backdrop-grayscale,backdropHueRotate:backdrop-hue-rotate,backdropInvert:backdrop-invert,backdropOpacity:backdrop-opacity,backdropSaturate:backdrop-saturate,backdropSepia:backdrop-sepia,borderCollapse:border,borderSpacing:border-spacing,borderSpacingX:border-spacing-x,borderSpacingY:border-spacing-y,tableLayout:table,transitionTimingFunction:ease,transitionDelay:delay,transitionDuration:duration,transitionProperty:transition-prop,transition:transition,animation:animation,animationName:animation-name,animationDelay:animation-delay,transformOrigin:origin,scale:scale,scaleX:scale-x,scaleY:scale-y,translate:translate,translateX:translate-x/x,translateY:translate-y/y,accentColor:accent,caretColor:caret,scrollBehavior:scroll,scrollbar:scrollbar,scrollMargin:scroll-m,scrollMarginX:scroll-mx,scrollMarginY:scroll-my,scrollMarginLeft:scroll-ml,scrollMarginRight:scroll-mr,scrollMarginTop:scroll-mt,scrollMarginBottom:scroll-mb,scrollMarginBlock:scroll-my,scrollMarginBlockEnd:scroll-mb,scrollMarginBlockStart:scroll-mt,scrollMarginInline:scroll-mx,scrollMarginInlineEnd:scroll-me,scrollMarginInlineStart:scroll-ms,scrollPadding:scroll-p,scrollPaddingBlock:scroll-pb,scrollPaddingBlockStart:scroll-pt,scrollPaddingBlockEnd:scroll-pb,scrollPaddingInline:scroll-px,scrollPaddingInlineEnd:scroll-pe,scrollPaddingInlineStart:scroll-ps,scrollPaddingX:scroll-px,scrollPaddingY:scroll-py,scrollPaddingLeft:scroll-pl,scrollPaddingRight:scroll-pr,scrollPaddingTop:scroll-pt,scrollPaddingBottom:scroll-pb,scrollSnapAlign:snap,scrollSnapStop:snap,scrollSnapType:snap,scrollSnapStrictness:strictness,scrollSnapMargin:snap-m,scrollSnapMarginTop:snap-mt,scrollSnapMarginBottom:snap-mb,scrollSnapMarginLeft:snap-ml,scrollSnapMarginRight:snap-mr,touchAction:touch,userSelect:select,fill:fill,stroke:stroke,strokeWidth:stroke-w,srOnly:sr,debug:debug,appearance:appearance,backfaceVisibility:backface,clipPath:clip-path,hyphens:hyphens,mask:mask,maskImage:mask-image,maskSize:mask-size,textSizeAdjust:text-size-adjust,textStyle:textStyle"
4
+ const utilities = "aspectRatio:aspect,boxDecorationBreak:decoration,zIndex:z,boxSizing:box,objectPosition:object,objectFit:object,overscrollBehavior:overscroll,overscrollBehaviorX:overscroll-x,overscrollBehaviorY:overscroll-y,position:pos/1,top:top,left:left,insetInline:inset-x,insetBlock:inset-y,inset:inset,insetBlockEnd:inset-b,insetBlockStart:inset-t,insetInlineEnd:end/insetEnd/1,insetInlineStart:start/insetStart/1,right:right,bottom:bottom,insetX:inset-x,insetY:inset-y,float:float,visibility:vis,display:d,hideFrom:hide,hideBelow:show,flexBasis:basis,flex:flex,flexDirection:flex/flexDir,flexGrow:grow,flexShrink:shrink,gridTemplateColumns:grid-cols,gridTemplateRows:grid-rows,gridColumn:col-span,gridRow:row-span,gridColumnStart:col-start,gridColumnEnd:col-end,gridAutoFlow:grid-flow,gridAutoColumns:auto-cols,gridAutoRows:auto-rows,gap:gap,gridGap:gap,gridRowGap:gap-x,gridColumnGap:gap-y,rowGap:gap-x,columnGap:gap-y,justifyContent:justify,alignContent:content,alignItems:items,alignSelf:self,padding:p/1,paddingLeft:pl/1,paddingRight:pr/1,paddingTop:pt/1,paddingBottom:pb/1,paddingBlock:py/1/paddingY,paddingBlockEnd:pb,paddingBlockStart:pt,paddingInline:px/paddingX/1,paddingInlineEnd:pe/1/paddingEnd,paddingInlineStart:ps/1/paddingStart,marginLeft:ml/1,marginRight:mr/1,marginTop:mt/1,marginBottom:mb/1,margin:m/1,marginBlock:my/1/marginY,marginBlockEnd:mb,marginBlockStart:mt,marginInline:mx/1/marginX,marginInlineEnd:me/1/marginEnd,marginInlineStart:ms/1/marginStart,outlineWidth:ring/ringWidth,outlineColor:ring/ringColor,outline:ring/1,outlineOffset:ring/ringOffset,divideX:divide-x,divideY:divide-y,divideColor:divide,divideStyle:divide,width:w/1,inlineSize:w,minWidth:min-w/minW,minInlineSize:min-w,maxWidth:max-w/maxW,maxInlineSize:max-w,height:h/1,blockSize:h,minHeight:min-h/minH,minBlockSize:min-h,maxHeight:max-h/maxH,maxBlockSize:max-b,color:text,fontFamily:font,fontSize:fs,fontWeight:font,fontSmoothing:smoothing,fontVariantNumeric:numeric,letterSpacing:tracking,lineHeight:leading,textAlign:text,textDecoration:text-decor,textDecorationColor:text-decor,textEmphasisColor:text-emphasis,textDecorationStyle:decoration,textDecorationThickness:decoration,textUnderlineOffset:underline-offset,textTransform:text,textIndent:indent,textShadow:text-shadow,textOverflow:text,verticalAlign:align,wordBreak:break,textWrap:text,truncate:truncate,lineClamp:clamp,listStyleType:list,listStylePosition:list,listStyleImage:list-img,backgroundPosition:bg/bgPosition,backgroundPositionX:bg-x/bgPositionX,backgroundPositionY:bg-y/bgPositionY,backgroundAttachment:bg/bgAttachment,backgroundClip:bg-clip/bgClip,background:bg/1,backgroundColor:bg/bgColor,backgroundOrigin:bg-origin/bgOrigin,backgroundImage:bg-img/bgImage,backgroundRepeat:bg-repeat/bgRepeat,backgroundBlendMode:bg-blend/bgBlendMode,backgroundSize:bg/bgSize,backgroundGradient:bg-gradient/bgGradient,textGradient:text-gradient,gradientFrom:from,gradientTo:to,gradientVia:via,borderRadius:rounded/1,borderTopLeftRadius:rounded-tl/roundedTopLeft,borderTopRightRadius:rounded-tr/roundedTopRight,borderBottomRightRadius:rounded-br/roundedBottomRight,borderBottomLeftRadius:rounded-bl/roundedBottomLeft,borderTopRadius:rounded-t/roundedTop,borderRightRadius:rounded-r/roundedRight,borderBottomRadius:rounded-b/roundedBottom,borderLeftRadius:rounded-l/roundedLeft,borderStartStartRadius:rounded-ss/roundedStartStart,borderStartEndRadius:rounded-se/roundedStartEnd,borderStartRadius:rounded-s/roundedStart,borderEndStartRadius:rounded-es/roundedEndStart,borderEndEndRadius:rounded-ee/roundedEndEnd,borderEndRadius:rounded-e/roundedEnd,border:border,borderWidth:border-w,borderTopWidth:border-tw,borderLeftWidth:border-lw,borderRightWidth:border-rw,borderBottomWidth:border-bw,borderColor:border,borderInline:border-x/borderX,borderInlineWidth:border-x/borderXWidth,borderInlineColor:border-x/borderXColor,borderBlock:border-y/borderY,borderBlockWidth:border-y/borderYWidth,borderBlockColor:border-y/borderYColor,borderLeft:border-l,borderLeftColor:border-l,borderInlineStart:border-s/borderStart,borderInlineStartWidth:border-s/borderStartWidth,borderInlineStartColor:border-s/borderStartColor,borderRight:border-r,borderRightColor:border-r,borderInlineEnd:border-e/borderEnd,borderInlineEndWidth:border-e/borderEndWidth,borderInlineEndColor:border-e/borderEndColor,borderTop:border-t,borderTopColor:border-t,borderBottom:border-b,borderBottomColor:border-b,borderBlockEnd:border-be,borderBlockEndColor:border-be,borderBlockStart:border-bs,borderBlockStartColor:border-bs,boxShadow:shadow/1,boxShadowColor:shadow/shadowColor,mixBlendMode:mix-blend,filter:filter,brightness:brightness,contrast:contrast,grayscale:grayscale,hueRotate:hue-rotate,invert:invert,saturate:saturate,sepia:sepia,dropShadow:drop-shadow,blur:blur,backdropFilter:backdrop,backdropBlur:backdrop-blur,backdropBrightness:backdrop-brightness,backdropContrast:backdrop-contrast,backdropGrayscale:backdrop-grayscale,backdropHueRotate:backdrop-hue-rotate,backdropInvert:backdrop-invert,backdropOpacity:backdrop-opacity,backdropSaturate:backdrop-saturate,backdropSepia:backdrop-sepia,borderCollapse:border,borderSpacing:border-spacing,borderSpacingX:border-spacing-x,borderSpacingY:border-spacing-y,tableLayout:table,transitionTimingFunction:ease,transitionDelay:delay,transitionDuration:duration,transitionProperty:transition-prop,transition:transition,animation:animation,animationName:animation-name,animationDelay:animation-delay,transformOrigin:origin,scale:scale,scaleX:scale-x,scaleY:scale-y,translate:translate,translateX:translate-x/x,translateY:translate-y/y,accentColor:accent,caretColor:caret,scrollBehavior:scroll,scrollbar:scrollbar,scrollMargin:scroll-m,scrollMarginX:scroll-mx,scrollMarginY:scroll-my,scrollMarginLeft:scroll-ml,scrollMarginRight:scroll-mr,scrollMarginTop:scroll-mt,scrollMarginBottom:scroll-mb,scrollMarginBlock:scroll-my,scrollMarginBlockEnd:scroll-mb,scrollMarginBlockStart:scroll-mt,scrollMarginInline:scroll-mx,scrollMarginInlineEnd:scroll-me,scrollMarginInlineStart:scroll-ms,scrollPadding:scroll-p,scrollPaddingBlock:scroll-pb,scrollPaddingBlockStart:scroll-pt,scrollPaddingBlockEnd:scroll-pb,scrollPaddingInline:scroll-px,scrollPaddingInlineEnd:scroll-pe,scrollPaddingInlineStart:scroll-ps,scrollPaddingX:scroll-px,scrollPaddingY:scroll-py,scrollPaddingLeft:scroll-pl,scrollPaddingRight:scroll-pr,scrollPaddingTop:scroll-pt,scrollPaddingBottom:scroll-pb,scrollSnapAlign:snap,scrollSnapStop:snap,scrollSnapType:snap,scrollSnapStrictness:strictness,scrollSnapMargin:snap-m,scrollSnapMarginTop:snap-mt,scrollSnapMarginBottom:snap-mb,scrollSnapMarginLeft:snap-ml,scrollSnapMarginRight:snap-mr,touchAction:touch,userSelect:select,fill:fill,stroke:stroke,strokeWidth:stroke-w,srOnly:sr,debug:debug,appearance:appearance,backfaceVisibility:backface,clipPath:clip-path,hyphens:hyphens,mask:mask,maskImage:mask-image,maskSize:mask-size,textSizeAdjust:text-size-adjust,container:cq,containerName:cq-name,containerType:cq-type,textStyle:textStyle"
5
5
 
6
6
  const classNameByProp = new Map()
7
7
  const shorthands = new Map()
@@ -14,7 +14,7 @@ function filterBaseConditions(c) {
14
14
  return c.slice().filter((v) => !isBaseCondition(v));
15
15
  }
16
16
 
17
- // src/css-important.ts
17
+ // src/important.ts
18
18
  var importantRegex = /\s*!(important)?/i;
19
19
  function isImportant(value) {
20
20
  return typeof value === "string" ? importantRegex.test(value) : false;
@@ -211,6 +211,34 @@ var hypenateProperty = memo((property) => {
211
211
  return property.replace(wordRegex, "-$1").replace(msRegex, "-ms-").toLowerCase();
212
212
  });
213
213
 
214
+ // src/is-css-function.ts
215
+ var fns = ["min", "max", "clamp", "calc"];
216
+ var fnRegExp = new RegExp(`^(${fns.join("|")})\\(.*\\)`);
217
+ var isCssFunction = (v) => typeof v === "string" && fnRegExp.test(v);
218
+
219
+ // src/is-css-unit.ts
220
+ var lengthUnits = "cm,mm,Q,in,pc,pt,px,em,ex,ch,rem,lh,rlh,vw,vh,vmin,vmax,vb,vi,svw,svh,lvw,lvh,dvw,dvh,cqw,cqh,cqi,cqb,cqmin,cqmax,%";
221
+ var lengthUnitsPattern = `(?:${lengthUnits.split(",").join("|")})`;
222
+ var lengthRegExp = new RegExp(`^[+-]?[0-9]*.?[0-9]+(?:[eE][+-]?[0-9]+)?${lengthUnitsPattern}$`);
223
+ var isCssUnit = (v) => typeof v === "string" && lengthRegExp.test(v);
224
+
225
+ // src/is-css-var.ts
226
+ var isCssVar = (v) => typeof v === "string" && /^var\(--.+\)$/.test(v);
227
+
228
+ // src/pattern-fns.ts
229
+ var patternFns = {
230
+ map: mapObject,
231
+ isCssFunction,
232
+ isCssVar,
233
+ isCssUnit
234
+ };
235
+ var getPatternStyles = (pattern, styles) => {
236
+ if (!pattern.defaultValues)
237
+ return styles;
238
+ const defaults = typeof pattern.defaultValues === "function" ? pattern.defaultValues(styles) : pattern.defaultValues;
239
+ return Object.assign({}, defaults, compact(styles));
240
+ };
241
+
214
242
  // src/slot.ts
215
243
  var getSlotRecipes = (recipe = {}) => {
216
244
  const init = (slot) => ({
@@ -260,6 +288,7 @@ export {
260
288
  createCss,
261
289
  createMergeCss,
262
290
  filterBaseConditions,
291
+ getPatternStyles,
263
292
  getSlotCompoundVariant,
264
293
  getSlotRecipes,
265
294
  hypenateProperty,
@@ -268,6 +297,7 @@ export {
268
297
  mapObject,
269
298
  memo,
270
299
  mergeProps,
300
+ patternFns,
271
301
  splitProps,
272
302
  toHash,
273
303
  uniq,
@@ -0,0 +1,10 @@
1
+ /* eslint-disable */
2
+ import type { FunctionComponent } from 'react'
3
+ import type { CqProperties } from '../patterns/cq';
4
+ import type { HTMLPandaProps } from '../types/jsx';
5
+ import type { DistributiveOmit } from '../types/system-types';
6
+
7
+ export interface CqProps extends CqProperties, DistributiveOmit<HTMLPandaProps<'div'>, keyof CqProperties > {}
8
+
9
+
10
+ export declare const Cq: FunctionComponent<CqProps>
@@ -0,0 +1,14 @@
1
+ import { createElement, forwardRef } from 'react'
2
+ import { mergeCss } from '../css/css.mjs';
3
+ import { splitProps } from '../helpers.mjs';
4
+ import { getCqStyle } from '../patterns/cq.mjs';
5
+ import { panda } from './factory.mjs';
6
+
7
+ export const Cq = /* @__PURE__ */ forwardRef(function Cq(props, ref) {
8
+ const [patternProps, restProps] = splitProps(props, ["name","type"])
9
+
10
+ const styleProps = getCqStyle(patternProps)
11
+ const mergedProps = { ref, ...styleProps, ...restProps }
12
+
13
+ return createElement(panda.div, mergedProps)
14
+ })
@@ -21,4 +21,5 @@ export * from './divider';
21
21
  export * from './float';
22
22
  export * from './bleed';
23
23
  export * from './visually-hidden';
24
+ export * from './cq';
24
25
  export type { HTMLPandaProps, PandaComponent } from '../types/jsx';
@@ -19,4 +19,5 @@ export * from './container.mjs';
19
19
  export * from './divider.mjs';
20
20
  export * from './float.mjs';
21
21
  export * from './bleed.mjs';
22
- export * from './visually-hidden.mjs';
22
+ export * from './visually-hidden.mjs';
23
+ export * from './cq.mjs';
@@ -1,7 +1,7 @@
1
1
  import { splitProps } from '../helpers.mjs';
2
2
  import { memo } from '../helpers.mjs';
3
3
  // src/index.ts
4
- var userGeneratedStr = "css,pos,insetEnd,end,insetStart,start,flexDir,p,pl,pr,pt,pb,py,paddingY,paddingX,px,pe,paddingEnd,ps,paddingStart,ml,mr,mt,mb,m,my,marginY,mx,marginX,me,marginEnd,ms,marginStart,ringWidth,ringColor,ring,ringOffset,w,minW,maxW,h,minH,maxH,bgPosition,bgPositionX,bgPositionY,bgAttachment,bgClip,bg,bgColor,bgOrigin,bgImage,bgRepeat,bgBlendMode,bgSize,bgGradient,rounded,roundedTopLeft,roundedTopRight,roundedBottomRight,roundedBottomLeft,roundedTop,roundedRight,roundedBottom,roundedLeft,roundedStartStart,roundedStartEnd,roundedStart,roundedEndStart,roundedEndEnd,roundedEnd,borderX,borderXWidth,borderXColor,borderY,borderYWidth,borderYColor,borderStart,borderStartWidth,borderStartColor,borderEnd,borderEndWidth,borderEndColor,shadow,shadowColor,x,y,aspectRatio,boxDecorationBreak,zIndex,boxSizing,objectPosition,objectFit,overscrollBehavior,overscrollBehaviorX,overscrollBehaviorY,position,top,left,insetInline,insetBlock,inset,insetBlockEnd,insetBlockStart,insetInlineEnd,insetInlineStart,right,bottom,insetX,insetY,float,visibility,display,hideFrom,hideBelow,flexBasis,flex,flexDirection,flexGrow,flexShrink,gridTemplateColumns,gridTemplateRows,gridColumn,gridRow,gridColumnStart,gridColumnEnd,gridAutoFlow,gridAutoColumns,gridAutoRows,gap,gridGap,gridRowGap,gridColumnGap,rowGap,columnGap,justifyContent,alignContent,alignItems,alignSelf,padding,paddingLeft,paddingRight,paddingTop,paddingBottom,paddingBlock,paddingBlockEnd,paddingBlockStart,paddingInline,paddingInlineEnd,paddingInlineStart,marginLeft,marginRight,marginTop,marginBottom,margin,marginBlock,marginBlockEnd,marginBlockStart,marginInline,marginInlineEnd,marginInlineStart,outlineWidth,outlineColor,outline,outlineOffset,divideX,divideY,divideColor,divideStyle,width,inlineSize,minWidth,minInlineSize,maxWidth,maxInlineSize,height,blockSize,minHeight,minBlockSize,maxHeight,maxBlockSize,color,fontFamily,fontSize,fontWeight,fontSmoothing,fontVariantNumeric,letterSpacing,lineHeight,textAlign,textDecoration,textDecorationColor,textEmphasisColor,textDecorationStyle,textDecorationThickness,textUnderlineOffset,textTransform,textIndent,textShadow,textOverflow,verticalAlign,wordBreak,textWrap,truncate,lineClamp,listStyleType,listStylePosition,listStyleImage,backgroundPosition,backgroundPositionX,backgroundPositionY,backgroundAttachment,backgroundClip,background,backgroundColor,backgroundOrigin,backgroundImage,backgroundRepeat,backgroundBlendMode,backgroundSize,backgroundGradient,textGradient,gradientFrom,gradientTo,gradientVia,borderRadius,borderTopLeftRadius,borderTopRightRadius,borderBottomRightRadius,borderBottomLeftRadius,borderTopRadius,borderRightRadius,borderBottomRadius,borderLeftRadius,borderStartStartRadius,borderStartEndRadius,borderStartRadius,borderEndStartRadius,borderEndEndRadius,borderEndRadius,border,borderWidth,borderTopWidth,borderLeftWidth,borderRightWidth,borderBottomWidth,borderColor,borderInline,borderInlineWidth,borderInlineColor,borderBlock,borderBlockWidth,borderBlockColor,borderLeft,borderLeftColor,borderInlineStart,borderInlineStartWidth,borderInlineStartColor,borderRight,borderRightColor,borderInlineEnd,borderInlineEndWidth,borderInlineEndColor,borderTop,borderTopColor,borderBottom,borderBottomColor,borderBlockEnd,borderBlockEndColor,borderBlockStart,borderBlockStartColor,opacity,boxShadow,boxShadowColor,mixBlendMode,filter,brightness,contrast,grayscale,hueRotate,invert,saturate,sepia,dropShadow,blur,backdropFilter,backdropBlur,backdropBrightness,backdropContrast,backdropGrayscale,backdropHueRotate,backdropInvert,backdropOpacity,backdropSaturate,backdropSepia,borderCollapse,borderSpacing,borderSpacingX,borderSpacingY,tableLayout,transitionTimingFunction,transitionDelay,transitionDuration,transitionProperty,transition,animation,animationName,animationDelay,transformOrigin,scale,scaleX,scaleY,translate,translateX,translateY,accentColor,caretColor,scrollBehavior,scrollbar,scrollMargin,scrollMarginX,scrollMarginY,scrollMarginLeft,scrollMarginRight,scrollMarginTop,scrollMarginBottom,scrollMarginBlock,scrollMarginBlockEnd,scrollMarginBlockStart,scrollMarginInline,scrollMarginInlineEnd,scrollMarginInlineStart,scrollPadding,scrollPaddingBlock,scrollPaddingBlockStart,scrollPaddingBlockEnd,scrollPaddingInline,scrollPaddingInlineEnd,scrollPaddingInlineStart,scrollPaddingX,scrollPaddingY,scrollPaddingLeft,scrollPaddingRight,scrollPaddingTop,scrollPaddingBottom,scrollSnapAlign,scrollSnapStop,scrollSnapType,scrollSnapStrictness,scrollSnapMargin,scrollSnapMarginTop,scrollSnapMarginBottom,scrollSnapMarginLeft,scrollSnapMarginRight,touchAction,userSelect,fill,stroke,strokeWidth,srOnly,debug,appearance,backfaceVisibility,clipPath,hyphens,mask,maskImage,maskSize,textSizeAdjust,colorPalette,_hover,_focus,_focusWithin,_focusVisible,_disabled,_active,_visited,_target,_readOnly,_readWrite,_empty,_checked,_enabled,_expanded,_highlighted,_before,_after,_firstLetter,_firstLine,_marker,_selection,_file,_backdrop,_first,_last,_only,_even,_odd,_firstOfType,_lastOfType,_onlyOfType,_peerFocus,_peerHover,_peerActive,_peerFocusWithin,_peerFocusVisible,_peerDisabled,_peerChecked,_peerInvalid,_peerExpanded,_peerPlaceholderShown,_groupFocus,_groupHover,_groupActive,_groupFocusWithin,_groupFocusVisible,_groupDisabled,_groupChecked,_groupExpanded,_groupInvalid,_indeterminate,_required,_valid,_invalid,_autofill,_inRange,_outOfRange,_placeholder,_placeholderShown,_pressed,_selected,_default,_optional,_open,_closed,_fullscreen,_loading,_currentPage,_currentStep,_motionReduce,_motionSafe,_print,_landscape,_portrait,_dark,_light,_osDark,_osLight,_highContrast,_lessContrast,_moreContrast,_ltr,_rtl,_scrollbar,_scrollbarThumb,_scrollbarTrack,_horizontal,_vertical,sm,smOnly,smDown,md,mdOnly,mdDown,lg,lgOnly,lgDown,xl,xlOnly,xlDown,2xl,2xlOnly,2xlDown,smToMd,smToLg,smToXl,smTo2xl,mdToLg,mdToXl,mdTo2xl,lgToXl,lgTo2xl,xlTo2xl,textStyle"
4
+ var userGeneratedStr = "css,pos,insetEnd,end,insetStart,start,flexDir,p,pl,pr,pt,pb,py,paddingY,paddingX,px,pe,paddingEnd,ps,paddingStart,ml,mr,mt,mb,m,my,marginY,mx,marginX,me,marginEnd,ms,marginStart,ringWidth,ringColor,ring,ringOffset,w,minW,maxW,h,minH,maxH,bgPosition,bgPositionX,bgPositionY,bgAttachment,bgClip,bg,bgColor,bgOrigin,bgImage,bgRepeat,bgBlendMode,bgSize,bgGradient,rounded,roundedTopLeft,roundedTopRight,roundedBottomRight,roundedBottomLeft,roundedTop,roundedRight,roundedBottom,roundedLeft,roundedStartStart,roundedStartEnd,roundedStart,roundedEndStart,roundedEndEnd,roundedEnd,borderX,borderXWidth,borderXColor,borderY,borderYWidth,borderYColor,borderStart,borderStartWidth,borderStartColor,borderEnd,borderEndWidth,borderEndColor,shadow,shadowColor,x,y,aspectRatio,boxDecorationBreak,zIndex,boxSizing,objectPosition,objectFit,overscrollBehavior,overscrollBehaviorX,overscrollBehaviorY,position,top,left,insetInline,insetBlock,inset,insetBlockEnd,insetBlockStart,insetInlineEnd,insetInlineStart,right,bottom,insetX,insetY,float,visibility,display,hideFrom,hideBelow,flexBasis,flex,flexDirection,flexGrow,flexShrink,gridTemplateColumns,gridTemplateRows,gridColumn,gridRow,gridColumnStart,gridColumnEnd,gridAutoFlow,gridAutoColumns,gridAutoRows,gap,gridGap,gridRowGap,gridColumnGap,rowGap,columnGap,justifyContent,alignContent,alignItems,alignSelf,padding,paddingLeft,paddingRight,paddingTop,paddingBottom,paddingBlock,paddingBlockEnd,paddingBlockStart,paddingInline,paddingInlineEnd,paddingInlineStart,marginLeft,marginRight,marginTop,marginBottom,margin,marginBlock,marginBlockEnd,marginBlockStart,marginInline,marginInlineEnd,marginInlineStart,outlineWidth,outlineColor,outline,outlineOffset,divideX,divideY,divideColor,divideStyle,width,inlineSize,minWidth,minInlineSize,maxWidth,maxInlineSize,height,blockSize,minHeight,minBlockSize,maxHeight,maxBlockSize,color,fontFamily,fontSize,fontWeight,fontSmoothing,fontVariantNumeric,letterSpacing,lineHeight,textAlign,textDecoration,textDecorationColor,textEmphasisColor,textDecorationStyle,textDecorationThickness,textUnderlineOffset,textTransform,textIndent,textShadow,textOverflow,verticalAlign,wordBreak,textWrap,truncate,lineClamp,listStyleType,listStylePosition,listStyleImage,backgroundPosition,backgroundPositionX,backgroundPositionY,backgroundAttachment,backgroundClip,background,backgroundColor,backgroundOrigin,backgroundImage,backgroundRepeat,backgroundBlendMode,backgroundSize,backgroundGradient,textGradient,gradientFrom,gradientTo,gradientVia,borderRadius,borderTopLeftRadius,borderTopRightRadius,borderBottomRightRadius,borderBottomLeftRadius,borderTopRadius,borderRightRadius,borderBottomRadius,borderLeftRadius,borderStartStartRadius,borderStartEndRadius,borderStartRadius,borderEndStartRadius,borderEndEndRadius,borderEndRadius,border,borderWidth,borderTopWidth,borderLeftWidth,borderRightWidth,borderBottomWidth,borderColor,borderInline,borderInlineWidth,borderInlineColor,borderBlock,borderBlockWidth,borderBlockColor,borderLeft,borderLeftColor,borderInlineStart,borderInlineStartWidth,borderInlineStartColor,borderRight,borderRightColor,borderInlineEnd,borderInlineEndWidth,borderInlineEndColor,borderTop,borderTopColor,borderBottom,borderBottomColor,borderBlockEnd,borderBlockEndColor,borderBlockStart,borderBlockStartColor,opacity,boxShadow,boxShadowColor,mixBlendMode,filter,brightness,contrast,grayscale,hueRotate,invert,saturate,sepia,dropShadow,blur,backdropFilter,backdropBlur,backdropBrightness,backdropContrast,backdropGrayscale,backdropHueRotate,backdropInvert,backdropOpacity,backdropSaturate,backdropSepia,borderCollapse,borderSpacing,borderSpacingX,borderSpacingY,tableLayout,transitionTimingFunction,transitionDelay,transitionDuration,transitionProperty,transition,animation,animationName,animationDelay,transformOrigin,scale,scaleX,scaleY,translate,translateX,translateY,accentColor,caretColor,scrollBehavior,scrollbar,scrollMargin,scrollMarginX,scrollMarginY,scrollMarginLeft,scrollMarginRight,scrollMarginTop,scrollMarginBottom,scrollMarginBlock,scrollMarginBlockEnd,scrollMarginBlockStart,scrollMarginInline,scrollMarginInlineEnd,scrollMarginInlineStart,scrollPadding,scrollPaddingBlock,scrollPaddingBlockStart,scrollPaddingBlockEnd,scrollPaddingInline,scrollPaddingInlineEnd,scrollPaddingInlineStart,scrollPaddingX,scrollPaddingY,scrollPaddingLeft,scrollPaddingRight,scrollPaddingTop,scrollPaddingBottom,scrollSnapAlign,scrollSnapStop,scrollSnapType,scrollSnapStrictness,scrollSnapMargin,scrollSnapMarginTop,scrollSnapMarginBottom,scrollSnapMarginLeft,scrollSnapMarginRight,touchAction,userSelect,fill,stroke,strokeWidth,srOnly,debug,appearance,backfaceVisibility,clipPath,hyphens,mask,maskImage,maskSize,textSizeAdjust,container,containerName,containerType,colorPalette,_hover,_focus,_focusWithin,_focusVisible,_disabled,_active,_visited,_target,_readOnly,_readWrite,_empty,_checked,_enabled,_expanded,_highlighted,_before,_after,_firstLetter,_firstLine,_marker,_selection,_file,_backdrop,_first,_last,_only,_even,_odd,_firstOfType,_lastOfType,_onlyOfType,_peerFocus,_peerHover,_peerActive,_peerFocusWithin,_peerFocusVisible,_peerDisabled,_peerChecked,_peerInvalid,_peerExpanded,_peerPlaceholderShown,_groupFocus,_groupHover,_groupActive,_groupFocusWithin,_groupFocusVisible,_groupDisabled,_groupChecked,_groupExpanded,_groupInvalid,_indeterminate,_required,_valid,_invalid,_autofill,_inRange,_outOfRange,_placeholder,_placeholderShown,_pressed,_selected,_default,_optional,_open,_closed,_fullscreen,_loading,_currentPage,_currentStep,_motionReduce,_motionSafe,_print,_landscape,_portrait,_dark,_light,_osDark,_osLight,_highContrast,_lessContrast,_moreContrast,_ltr,_rtl,_scrollbar,_scrollbarThumb,_scrollbarTrack,_horizontal,_vertical,sm,smOnly,smDown,md,mdOnly,mdDown,lg,lgOnly,lgDown,xl,xlOnly,xlDown,2xl,2xlOnly,2xlDown,smToMd,smToLg,smToXl,smTo2xl,mdToLg,mdToXl,mdTo2xl,lgToXl,lgTo2xl,xlTo2xl,@/xs,@/sm,@/md,@/lg,@/xl,@/2xl,@/3xl,@/4xl,@/5xl,@/6xl,@/7xl,@/8xl,textStyle"
5
5
  var userGenerated = userGeneratedStr.split(",");
6
6
  var cssPropertiesStr = "WebkitAppearance,WebkitBorderBefore,WebkitBorderBeforeColor,WebkitBorderBeforeStyle,WebkitBorderBeforeWidth,WebkitBoxReflect,WebkitLineClamp,WebkitMask,WebkitMaskAttachment,WebkitMaskClip,WebkitMaskComposite,WebkitMaskImage,WebkitMaskOrigin,WebkitMaskPosition,WebkitMaskPositionX,WebkitMaskPositionY,WebkitMaskRepeat,WebkitMaskRepeatX,WebkitMaskRepeatY,WebkitMaskSize,WebkitOverflowScrolling,WebkitTapHighlightColor,WebkitTextFillColor,WebkitTextStroke,WebkitTextStrokeColor,WebkitTextStrokeWidth,WebkitTouchCallout,WebkitUserModify,accentColor,alignContent,alignItems,alignSelf,alignTracks,all,animation,animationComposition,animationDelay,animationDirection,animationDuration,animationFillMode,animationIterationCount,animationName,animationPlayState,animationTimingFunction,animationTimeline,appearance,aspectRatio,azimuth,backdropFilter,backfaceVisibility,background,backgroundAttachment,backgroundBlendMode,backgroundClip,backgroundColor,backgroundImage,backgroundOrigin,backgroundPosition,backgroundPositionX,backgroundPositionY,backgroundRepeat,backgroundSize,blockOverflow,blockSize,border,borderBlock,borderBlockColor,borderBlockStyle,borderBlockWidth,borderBlockEnd,borderBlockEndColor,borderBlockEndStyle,borderBlockEndWidth,borderBlockStart,borderBlockStartColor,borderBlockStartStyle,borderBlockStartWidth,borderBottom,borderBottomColor,borderBottomLeftRadius,borderBottomRightRadius,borderBottomStyle,borderBottomWidth,borderCollapse,borderColor,borderEndEndRadius,borderEndStartRadius,borderImage,borderImageOutset,borderImageRepeat,borderImageSlice,borderImageSource,borderImageWidth,borderInline,borderInlineEnd,borderInlineColor,borderInlineStyle,borderInlineWidth,borderInlineEndColor,borderInlineEndStyle,borderInlineEndWidth,borderInlineStart,borderInlineStartColor,borderInlineStartStyle,borderInlineStartWidth,borderLeft,borderLeftColor,borderLeftStyle,borderLeftWidth,borderRadius,borderRight,borderRightColor,borderRightStyle,borderRightWidth,borderSpacing,borderStartEndRadius,borderStartStartRadius,borderStyle,borderTop,borderTopColor,borderTopLeftRadius,borderTopRightRadius,borderTopStyle,borderTopWidth,borderWidth,bottom,boxAlign,boxDecorationBreak,boxDirection,boxFlex,boxFlexGroup,boxLines,boxOrdinalGroup,boxOrient,boxPack,boxShadow,boxSizing,breakAfter,breakBefore,breakInside,captionSide,caret,caretColor,caretShape,clear,clip,clipPath,color,colorScheme,columnCount,columnFill,columnGap,columnRule,columnRuleColor,columnRuleStyle,columnRuleWidth,columnSpan,columnWidth,columns,contain,containIntrinsicSize,containIntrinsicBlockSize,containIntrinsicHeight,containIntrinsicInlineSize,containIntrinsicWidth,container,containerName,containerType,content,contentVisibility,counterIncrement,counterReset,counterSet,cursor,direction,display,emptyCells,filter,flex,flexBasis,flexDirection,flexFlow,flexGrow,flexShrink,flexWrap,float,font,fontFamily,fontFeatureSettings,fontKerning,fontLanguageOverride,fontOpticalSizing,fontPalette,fontVariationSettings,fontSize,fontSizeAdjust,fontSmooth,fontStretch,fontStyle,fontSynthesis,fontVariant,fontVariantAlternates,fontVariantCaps,fontVariantEastAsian,fontVariantEmoji,fontVariantLigatures,fontVariantNumeric,fontVariantPosition,fontWeight,forcedColorAdjust,gap,grid,gridArea,gridAutoColumns,gridAutoFlow,gridAutoRows,gridColumn,gridColumnEnd,gridColumnGap,gridColumnStart,gridGap,gridRow,gridRowEnd,gridRowGap,gridRowStart,gridTemplate,gridTemplateAreas,gridTemplateColumns,gridTemplateRows,hangingPunctuation,height,hyphenateCharacter,hyphenateLimitChars,hyphens,imageOrientation,imageRendering,imageResolution,imeMode,initialLetter,initialLetterAlign,inlineSize,inputSecurity,inset,insetBlock,insetBlockEnd,insetBlockStart,insetInline,insetInlineEnd,insetInlineStart,isolation,justifyContent,justifyItems,justifySelf,justifyTracks,left,letterSpacing,lineBreak,lineClamp,lineHeight,lineHeightStep,listStyle,listStyleImage,listStylePosition,listStyleType,margin,marginBlock,marginBlockEnd,marginBlockStart,marginBottom,marginInline,marginInlineEnd,marginInlineStart,marginLeft,marginRight,marginTop,marginTrim,mask,maskBorder,maskBorderMode,maskBorderOutset,maskBorderRepeat,maskBorderSlice,maskBorderSource,maskBorderWidth,maskClip,maskComposite,maskImage,maskMode,maskOrigin,maskPosition,maskRepeat,maskSize,maskType,masonryAutoFlow,mathDepth,mathShift,mathStyle,maxBlockSize,maxHeight,maxInlineSize,maxLines,maxWidth,minBlockSize,minHeight,minInlineSize,minWidth,mixBlendMode,objectFit,objectPosition,offset,offsetAnchor,offsetDistance,offsetPath,offsetPosition,offsetRotate,opacity,order,orphans,outline,outlineColor,outlineOffset,outlineStyle,outlineWidth,overflow,overflowAnchor,overflowBlock,overflowClipBox,overflowClipMargin,overflowInline,overflowWrap,overflowX,overflowY,overscrollBehavior,overscrollBehaviorBlock,overscrollBehaviorInline,overscrollBehaviorX,overscrollBehaviorY,padding,paddingBlock,paddingBlockEnd,paddingBlockStart,paddingBottom,paddingInline,paddingInlineEnd,paddingInlineStart,paddingLeft,paddingRight,paddingTop,page,pageBreakAfter,pageBreakBefore,pageBreakInside,paintOrder,perspective,perspectiveOrigin,placeContent,placeItems,placeSelf,pointerEvents,position,printColorAdjust,quotes,resize,right,rotate,rowGap,rubyAlign,rubyMerge,rubyPosition,scale,scrollbarColor,scrollbarGutter,scrollbarWidth,scrollBehavior,scrollMargin,scrollMarginBlock,scrollMarginBlockStart,scrollMarginBlockEnd,scrollMarginBottom,scrollMarginInline,scrollMarginInlineStart,scrollMarginInlineEnd,scrollMarginLeft,scrollMarginRight,scrollMarginTop,scrollPadding,scrollPaddingBlock,scrollPaddingBlockStart,scrollPaddingBlockEnd,scrollPaddingBottom,scrollPaddingInline,scrollPaddingInlineStart,scrollPaddingInlineEnd,scrollPaddingLeft,scrollPaddingRight,scrollPaddingTop,scrollSnapAlign,scrollSnapCoordinate,scrollSnapDestination,scrollSnapPointsX,scrollSnapPointsY,scrollSnapStop,scrollSnapType,scrollSnapTypeX,scrollSnapTypeY,scrollTimeline,scrollTimelineAxis,scrollTimelineName,shapeImageThreshold,shapeMargin,shapeOutside,tabSize,tableLayout,textAlign,textAlignLast,textCombineUpright,textDecoration,textDecorationColor,textDecorationLine,textDecorationSkip,textDecorationSkipInk,textDecorationStyle,textDecorationThickness,textEmphasis,textEmphasisColor,textEmphasisPosition,textEmphasisStyle,textIndent,textJustify,textOrientation,textOverflow,textRendering,textShadow,textSizeAdjust,textTransform,textUnderlineOffset,textUnderlinePosition,top,touchAction,transform,transformBox,transformOrigin,transformStyle,transition,transitionDelay,transitionDuration,transitionProperty,transitionTimingFunction,translate,unicodeBidi,userSelect,verticalAlign,viewTransitionName,visibility,whiteSpace,widows,width,willChange,wordBreak,wordSpacing,wordWrap,writingMode,zIndex,zoom,alignmentBaseline,baselineShift,clipRule,colorInterpolation,colorRendering,dominantBaseline,fill,fillOpacity,fillRule,floodColor,floodOpacity,glyphOrientationVertical,lightingColor,marker,markerEnd,markerMid,markerStart,shapeRendering,stopColor,stopOpacity,stroke,strokeDasharray,strokeDashoffset,strokeLinecap,strokeLinejoin,strokeMiterlimit,strokeOpacity,strokeWidth,textAnchor,vectorEffect";
7
7
  var allCssProperties = cssPropertiesStr.split(",").concat(userGenerated);
@@ -1,4 +1,4 @@
1
- import { mapObject } from '../helpers.mjs';
1
+ import { getPatternStyles, patternFns } from '../helpers.mjs';
2
2
  import { css } from '../css/index.mjs';
3
3
 
4
4
  const aspectRatioConfig = {
@@ -29,7 +29,10 @@ transform(props, { map }) {
29
29
  };
30
30
  }}
31
31
 
32
- export const getAspectRatioStyle = (styles = {}) => aspectRatioConfig.transform(styles, { map: mapObject })
32
+ export const getAspectRatioStyle = (styles = {}) => {
33
+ const _styles = getPatternStyles(aspectRatioConfig, styles)
34
+ return aspectRatioConfig.transform(_styles, patternFns)
35
+ }
33
36
 
34
37
  export const aspectRatio = (styles) => css(getAspectRatioStyle(styles))
35
38
  aspectRatio.raw = getAspectRatioStyle
@@ -1,19 +1,24 @@
1
- import { mapObject } from '../helpers.mjs';
1
+ import { getPatternStyles, patternFns } from '../helpers.mjs';
2
2
  import { css } from '../css/index.mjs';
3
3
 
4
4
  const bleedConfig = {
5
- transform(props) {
6
- const { inline = "0", block = "0", ...rest } = props;
5
+ transform(props, { map, isCssUnit, isCssVar }) {
6
+ const { inline, block, ...rest } = props;
7
+ const valueFn = (v) => isCssUnit(v) || isCssVar(v) ? v : `token(spacing.${v}, ${v})`;
7
8
  return {
8
- "--bleed-x": `spacing.${inline}`,
9
- "--bleed-y": `spacing.${block}`,
9
+ "--bleed-x": map(inline, valueFn),
10
+ "--bleed-y": map(block, valueFn),
10
11
  marginInline: "calc(var(--bleed-x, 0) * -1)",
11
12
  marginBlock: "calc(var(--bleed-y, 0) * -1)",
12
13
  ...rest
13
14
  };
14
- }}
15
+ },
16
+ defaultValues:{inline:'0',block:'0'}}
15
17
 
16
- export const getBleedStyle = (styles = {}) => bleedConfig.transform(styles, { map: mapObject })
18
+ export const getBleedStyle = (styles = {}) => {
19
+ const _styles = getPatternStyles(bleedConfig, styles)
20
+ return bleedConfig.transform(_styles, patternFns)
21
+ }
17
22
 
18
23
  export const bleed = (styles) => css(getBleedStyle(styles))
19
24
  bleed.raw = getBleedStyle
@@ -1,4 +1,4 @@
1
- import { mapObject } from '../helpers.mjs';
1
+ import { getPatternStyles, patternFns } from '../helpers.mjs';
2
2
  import { css } from '../css/index.mjs';
3
3
 
4
4
  const boxConfig = {
@@ -6,7 +6,10 @@ transform(props) {
6
6
  return props;
7
7
  }}
8
8
 
9
- export const getBoxStyle = (styles = {}) => boxConfig.transform(styles, { map: mapObject })
9
+ export const getBoxStyle = (styles = {}) => {
10
+ const _styles = getPatternStyles(boxConfig, styles)
11
+ return boxConfig.transform(_styles, patternFns)
12
+ }
10
13
 
11
14
  export const box = (styles) => css(getBoxStyle(styles))
12
15
  box.raw = getBoxStyle
@@ -1,4 +1,4 @@
1
- import { mapObject } from '../helpers.mjs';
1
+ import { getPatternStyles, patternFns } from '../helpers.mjs';
2
2
  import { css } from '../css/index.mjs';
3
3
 
4
4
  const centerConfig = {
@@ -12,7 +12,10 @@ transform(props) {
12
12
  };
13
13
  }}
14
14
 
15
- export const getCenterStyle = (styles = {}) => centerConfig.transform(styles, { map: mapObject })
15
+ export const getCenterStyle = (styles = {}) => {
16
+ const _styles = getPatternStyles(centerConfig, styles)
17
+ return centerConfig.transform(_styles, patternFns)
18
+ }
16
19
 
17
20
  export const center = (styles) => css(getCenterStyle(styles))
18
21
  center.raw = getCenterStyle
@@ -1,4 +1,4 @@
1
- import { mapObject } from '../helpers.mjs';
1
+ import { getPatternStyles, patternFns } from '../helpers.mjs';
2
2
  import { css } from '../css/index.mjs';
3
3
 
4
4
  const circleConfig = {
@@ -16,7 +16,10 @@ transform(props) {
16
16
  };
17
17
  }}
18
18
 
19
- export const getCircleStyle = (styles = {}) => circleConfig.transform(styles, { map: mapObject })
19
+ export const getCircleStyle = (styles = {}) => {
20
+ const _styles = getPatternStyles(circleConfig, styles)
21
+ return circleConfig.transform(_styles, patternFns)
22
+ }
20
23
 
21
24
  export const circle = (styles) => css(getCircleStyle(styles))
22
25
  circle.raw = getCircleStyle
@@ -1,4 +1,4 @@
1
- import { mapObject } from '../helpers.mjs';
1
+ import { getPatternStyles, patternFns } from '../helpers.mjs';
2
2
  import { css } from '../css/index.mjs';
3
3
 
4
4
  const containerConfig = {
@@ -12,7 +12,10 @@ transform(props) {
12
12
  };
13
13
  }}
14
14
 
15
- export const getContainerStyle = (styles = {}) => containerConfig.transform(styles, { map: mapObject })
15
+ export const getContainerStyle = (styles = {}) => {
16
+ const _styles = getPatternStyles(containerConfig, styles)
17
+ return containerConfig.transform(_styles, patternFns)
18
+ }
16
19
 
17
20
  export const container = (styles) => css(getContainerStyle(styles))
18
21
  container.raw = getContainerStyle
@@ -0,0 +1,22 @@
1
+ /* eslint-disable */
2
+ import type { SystemStyleObject, ConditionalValue } from '../types/index';
3
+ import type { Properties } from '../types/csstype';
4
+ import type { PropertyValue } from '../types/prop-type';
5
+ import type { DistributiveOmit } from '../types/system-types';
6
+ import type { Tokens } from '../tokens/index';
7
+
8
+ export interface CqProperties {
9
+ name?: ConditionalValue<Tokens["containerNames"] | Properties["containerName"]>
10
+ type?: PropertyValue<'containerType'>
11
+ }
12
+
13
+
14
+ interface CqStyles extends CqProperties, DistributiveOmit<SystemStyleObject, keyof CqProperties > {}
15
+
16
+ interface CqPatternFn {
17
+ (styles?: CqStyles): string
18
+ raw: (styles?: CqStyles) => SystemStyleObject
19
+ }
20
+
21
+
22
+ export declare const cq: CqPatternFn;
@@ -0,0 +1,21 @@
1
+ import { getPatternStyles, patternFns } from '../helpers.mjs';
2
+ import { css } from '../css/index.mjs';
3
+
4
+ const cqConfig = {
5
+ transform(props) {
6
+ const { name, type, ...rest } = props;
7
+ return {
8
+ containerType: type,
9
+ containerName: name,
10
+ ...rest
11
+ };
12
+ },
13
+ defaultValues:{type:'inline-size'}}
14
+
15
+ export const getCqStyle = (styles = {}) => {
16
+ const _styles = getPatternStyles(cqConfig, styles)
17
+ return cqConfig.transform(_styles, patternFns)
18
+ }
19
+
20
+ export const cq = (styles) => css(getCqStyle(styles))
21
+ cq.raw = getCqStyle
@@ -1,9 +1,9 @@
1
- import { mapObject } from '../helpers.mjs';
1
+ import { getPatternStyles, patternFns } from '../helpers.mjs';
2
2
  import { css } from '../css/index.mjs';
3
3
 
4
4
  const dividerConfig = {
5
5
  transform(props, { map }) {
6
- const { orientation = "horizontal", thickness = "1px", color, ...rest } = props;
6
+ const { orientation, thickness, color, ...rest } = props;
7
7
  return {
8
8
  "--thickness": thickness,
9
9
  width: map(orientation, (v) => v === "vertical" ? void 0 : "100%"),
@@ -13,9 +13,13 @@ transform(props, { map }) {
13
13
  borderColor: color,
14
14
  ...rest
15
15
  };
16
- }}
16
+ },
17
+ defaultValues:{orientation:'horizontal',thickness:'1px'}}
17
18
 
18
- export const getDividerStyle = (styles = {}) => dividerConfig.transform(styles, { map: mapObject })
19
+ export const getDividerStyle = (styles = {}) => {
20
+ const _styles = getPatternStyles(dividerConfig, styles)
21
+ return dividerConfig.transform(_styles, patternFns)
22
+ }
19
23
 
20
24
  export const divider = (styles) => css(getDividerStyle(styles))
21
25
  divider.raw = getDividerStyle
@@ -1,4 +1,4 @@
1
- import { mapObject } from '../helpers.mjs';
1
+ import { getPatternStyles, patternFns } from '../helpers.mjs';
2
2
  import { css } from '../css/index.mjs';
3
3
 
4
4
  const flexConfig = {
@@ -17,7 +17,10 @@ transform(props) {
17
17
  };
18
18
  }}
19
19
 
20
- export const getFlexStyle = (styles = {}) => flexConfig.transform(styles, { map: mapObject })
20
+ export const getFlexStyle = (styles = {}) => {
21
+ const _styles = getPatternStyles(flexConfig, styles)
22
+ return flexConfig.transform(_styles, patternFns)
23
+ }
21
24
 
22
25
  export const flex = (styles) => css(getFlexStyle(styles))
23
26
  flex.raw = getFlexStyle
@@ -1,9 +1,9 @@
1
- import { mapObject } from '../helpers.mjs';
1
+ import { getPatternStyles, patternFns } from '../helpers.mjs';
2
2
  import { css } from '../css/index.mjs';
3
3
 
4
4
  const floatConfig = {
5
5
  transform(props, { map }) {
6
- const { offset = "0", offsetX = offset, offsetY = offset, placement = "top-end", ...rest } = props;
6
+ const { offset, offsetX, offsetY, placement, ...rest } = props;
7
7
  return {
8
8
  display: "inline-flex",
9
9
  justifyContent: "center",
@@ -37,9 +37,16 @@ transform(props, { map }) {
37
37
  }),
38
38
  ...rest
39
39
  };
40
+ },
41
+ defaultValues(props) {
42
+ const offset = props.offset || "0";
43
+ return { offset, offsetX: offset, offsetY: offset, placement: "top-end" };
40
44
  }}
41
45
 
42
- export const getFloatStyle = (styles = {}) => floatConfig.transform(styles, { map: mapObject })
46
+ export const getFloatStyle = (styles = {}) => {
47
+ const _styles = getPatternStyles(floatConfig, styles)
48
+ return floatConfig.transform(_styles, patternFns)
49
+ }
43
50
 
44
51
  export const float = (styles) => css(getFloatStyle(styles))
45
52
  float.raw = getFloatStyle
@@ -1,4 +1,4 @@
1
- import { mapObject } from '../helpers.mjs';
1
+ import { getPatternStyles, patternFns } from '../helpers.mjs';
2
2
  import { css } from '../css/index.mjs';
3
3
 
4
4
  const gridItemConfig = {
@@ -16,7 +16,10 @@ transform(props, { map }) {
16
16
  };
17
17
  }}
18
18
 
19
- export const getGridItemStyle = (styles = {}) => gridItemConfig.transform(styles, { map: mapObject })
19
+ export const getGridItemStyle = (styles = {}) => {
20
+ const _styles = getPatternStyles(gridItemConfig, styles)
21
+ return gridItemConfig.transform(_styles, patternFns)
22
+ }
20
23
 
21
24
  export const gridItem = (styles) => css(getGridItemStyle(styles))
22
25
  gridItem.raw = getGridItemStyle
@@ -1,11 +1,10 @@
1
- import { mapObject } from '../helpers.mjs';
1
+ import { getPatternStyles, patternFns } from '../helpers.mjs';
2
2
  import { css } from '../css/index.mjs';
3
3
 
4
4
  const gridConfig = {
5
- transform(props, { map }) {
6
- const regex = /\d+(cm|in|pt|em|px|rem|vh|vmax|vmin|vw|ch|lh|%)$/;
7
- const { columnGap, rowGap, gap = columnGap || rowGap ? void 0 : "10px", columns, minChildWidth, ...rest } = props;
8
- const getValue = (v) => regex.test(v) ? v : `token(sizes.${v}, ${v})`;
5
+ transform(props, { map, isCssUnit }) {
6
+ const { columnGap, rowGap, gap, columns, minChildWidth, ...rest } = props;
7
+ const getValue = (v) => isCssUnit(v) ? v : `token(sizes.${v}, ${v})`;
9
8
  return {
10
9
  display: "grid",
11
10
  gridTemplateColumns: columns != null ? map(columns, (v) => `repeat(${v}, minmax(0, 1fr))`) : minChildWidth != null ? map(minChildWidth, (v) => `repeat(auto-fit, minmax(${getValue(v)}, 1fr))`) : void 0,
@@ -14,9 +13,15 @@ transform(props, { map }) {
14
13
  rowGap,
15
14
  ...rest
16
15
  };
16
+ },
17
+ defaultValues(props) {
18
+ return { gap: props.columnGap || props.rowGap ? void 0 : "10px" };
17
19
  }}
18
20
 
19
- export const getGridStyle = (styles = {}) => gridConfig.transform(styles, { map: mapObject })
21
+ export const getGridStyle = (styles = {}) => {
22
+ const _styles = getPatternStyles(gridConfig, styles)
23
+ return gridConfig.transform(_styles, patternFns)
24
+ }
20
25
 
21
26
  export const grid = (styles) => css(getGridStyle(styles))
22
27
  grid.raw = getGridStyle
@@ -1,9 +1,9 @@
1
- import { mapObject } from '../helpers.mjs';
1
+ import { getPatternStyles, patternFns } from '../helpers.mjs';
2
2
  import { css } from '../css/index.mjs';
3
3
 
4
4
  const hstackConfig = {
5
5
  transform(props) {
6
- const { justify, gap = "10px", ...rest } = props;
6
+ const { justify, gap, ...rest } = props;
7
7
  return {
8
8
  display: "flex",
9
9
  alignItems: "center",
@@ -12,9 +12,13 @@ transform(props) {
12
12
  flexDirection: "row",
13
13
  ...rest
14
14
  };
15
- }}
15
+ },
16
+ defaultValues:{gap:'10px'}}
16
17
 
17
- export const getHstackStyle = (styles = {}) => hstackConfig.transform(styles, { map: mapObject })
18
+ export const getHstackStyle = (styles = {}) => {
19
+ const _styles = getPatternStyles(hstackConfig, styles)
20
+ return hstackConfig.transform(_styles, patternFns)
21
+ }
18
22
 
19
23
  export const hstack = (styles) => css(getHstackStyle(styles))
20
24
  hstack.raw = getHstackStyle
@@ -18,4 +18,5 @@ export * from './container';
18
18
  export * from './divider';
19
19
  export * from './float';
20
20
  export * from './bleed';
21
- export * from './visually-hidden';
21
+ export * from './visually-hidden';
22
+ export * from './cq';
@@ -17,4 +17,5 @@ export * from './container.mjs';
17
17
  export * from './divider.mjs';
18
18
  export * from './float.mjs';
19
19
  export * from './bleed.mjs';
20
- export * from './visually-hidden.mjs';
20
+ export * from './visually-hidden.mjs';
21
+ export * from './cq.mjs';
@@ -1,4 +1,4 @@
1
- import { mapObject } from '../helpers.mjs';
1
+ import { getPatternStyles, patternFns } from '../helpers.mjs';
2
2
  import { css } from '../css/index.mjs';
3
3
 
4
4
  const linkBoxConfig = {
@@ -13,7 +13,10 @@ transform(props) {
13
13
  };
14
14
  }}
15
15
 
16
- export const getLinkBoxStyle = (styles = {}) => linkBoxConfig.transform(styles, { map: mapObject })
16
+ export const getLinkBoxStyle = (styles = {}) => {
17
+ const _styles = getPatternStyles(linkBoxConfig, styles)
18
+ return linkBoxConfig.transform(_styles, patternFns)
19
+ }
17
20
 
18
21
  export const linkBox = (styles) => css(getLinkBoxStyle(styles))
19
22
  linkBox.raw = getLinkBoxStyle
@@ -1,4 +1,4 @@
1
- import { mapObject } from '../helpers.mjs';
1
+ import { getPatternStyles, patternFns } from '../helpers.mjs';
2
2
  import { css } from '../css/index.mjs';
3
3
 
4
4
  const linkOverlayConfig = {
@@ -18,7 +18,10 @@ transform(props) {
18
18
  };
19
19
  }}
20
20
 
21
- export const getLinkOverlayStyle = (styles = {}) => linkOverlayConfig.transform(styles, { map: mapObject })
21
+ export const getLinkOverlayStyle = (styles = {}) => {
22
+ const _styles = getPatternStyles(linkOverlayConfig, styles)
23
+ return linkOverlayConfig.transform(_styles, patternFns)
24
+ }
22
25
 
23
26
  export const linkOverlay = (styles) => css(getLinkOverlayStyle(styles))
24
27
  linkOverlay.raw = getLinkOverlayStyle
@@ -1,4 +1,4 @@
1
- import { mapObject } from '../helpers.mjs';
1
+ import { getPatternStyles, patternFns } from '../helpers.mjs';
2
2
  import { css } from '../css/index.mjs';
3
3
 
4
4
  const spacerConfig = {
@@ -12,7 +12,10 @@ transform(props, { map }) {
12
12
  };
13
13
  }}
14
14
 
15
- export const getSpacerStyle = (styles = {}) => spacerConfig.transform(styles, { map: mapObject })
15
+ export const getSpacerStyle = (styles = {}) => {
16
+ const _styles = getPatternStyles(spacerConfig, styles)
17
+ return spacerConfig.transform(_styles, patternFns)
18
+ }
16
19
 
17
20
  export const spacer = (styles) => css(getSpacerStyle(styles))
18
21
  spacer.raw = getSpacerStyle
@@ -1,4 +1,4 @@
1
- import { mapObject } from '../helpers.mjs';
1
+ import { getPatternStyles, patternFns } from '../helpers.mjs';
2
2
  import { css } from '../css/index.mjs';
3
3
 
4
4
  const squareConfig = {
@@ -15,7 +15,10 @@ transform(props) {
15
15
  };
16
16
  }}
17
17
 
18
- export const getSquareStyle = (styles = {}) => squareConfig.transform(styles, { map: mapObject })
18
+ export const getSquareStyle = (styles = {}) => {
19
+ const _styles = getPatternStyles(squareConfig, styles)
20
+ return squareConfig.transform(_styles, patternFns)
21
+ }
19
22
 
20
23
  export const square = (styles) => css(getSquareStyle(styles))
21
24
  square.raw = getSquareStyle
@@ -1,9 +1,9 @@
1
- import { mapObject } from '../helpers.mjs';
1
+ import { getPatternStyles, patternFns } from '../helpers.mjs';
2
2
  import { css } from '../css/index.mjs';
3
3
 
4
4
  const stackConfig = {
5
5
  transform(props) {
6
- const { align, justify, direction = "column", gap = "10px", ...rest } = props;
6
+ const { align, justify, direction, gap, ...rest } = props;
7
7
  return {
8
8
  display: "flex",
9
9
  flexDirection: direction,
@@ -12,9 +12,13 @@ transform(props) {
12
12
  gap,
13
13
  ...rest
14
14
  };
15
- }}
15
+ },
16
+ defaultValues:{direction:'column',gap:'10px'}}
16
17
 
17
- export const getStackStyle = (styles = {}) => stackConfig.transform(styles, { map: mapObject })
18
+ export const getStackStyle = (styles = {}) => {
19
+ const _styles = getPatternStyles(stackConfig, styles)
20
+ return stackConfig.transform(_styles, patternFns)
21
+ }
18
22
 
19
23
  export const stack = (styles) => css(getStackStyle(styles))
20
24
  stack.raw = getStackStyle
@@ -1,4 +1,4 @@
1
- import { mapObject } from '../helpers.mjs';
1
+ import { getPatternStyles, patternFns } from '../helpers.mjs';
2
2
  import { css } from '../css/index.mjs';
3
3
 
4
4
  const visuallyHiddenConfig = {
@@ -9,7 +9,10 @@ transform(props) {
9
9
  };
10
10
  }}
11
11
 
12
- export const getVisuallyHiddenStyle = (styles = {}) => visuallyHiddenConfig.transform(styles, { map: mapObject })
12
+ export const getVisuallyHiddenStyle = (styles = {}) => {
13
+ const _styles = getPatternStyles(visuallyHiddenConfig, styles)
14
+ return visuallyHiddenConfig.transform(_styles, patternFns)
15
+ }
13
16
 
14
17
  export const visuallyHidden = (styles) => css(getVisuallyHiddenStyle(styles))
15
18
  visuallyHidden.raw = getVisuallyHiddenStyle
@@ -1,9 +1,9 @@
1
- import { mapObject } from '../helpers.mjs';
1
+ import { getPatternStyles, patternFns } from '../helpers.mjs';
2
2
  import { css } from '../css/index.mjs';
3
3
 
4
4
  const vstackConfig = {
5
5
  transform(props) {
6
- const { justify, gap = "10px", ...rest } = props;
6
+ const { justify, gap, ...rest } = props;
7
7
  return {
8
8
  display: "flex",
9
9
  alignItems: "center",
@@ -12,9 +12,13 @@ transform(props) {
12
12
  flexDirection: "column",
13
13
  ...rest
14
14
  };
15
- }}
15
+ },
16
+ defaultValues:{gap:'10px'}}
16
17
 
17
- export const getVstackStyle = (styles = {}) => vstackConfig.transform(styles, { map: mapObject })
18
+ export const getVstackStyle = (styles = {}) => {
19
+ const _styles = getPatternStyles(vstackConfig, styles)
20
+ return vstackConfig.transform(_styles, patternFns)
21
+ }
18
22
 
19
23
  export const vstack = (styles) => css(getVstackStyle(styles))
20
24
  vstack.raw = getVstackStyle
@@ -1,4 +1,4 @@
1
- import { mapObject } from '../helpers.mjs';
1
+ import { getPatternStyles, patternFns } from '../helpers.mjs';
2
2
  import { css } from '../css/index.mjs';
3
3
 
4
4
  const wrapConfig = {
@@ -16,7 +16,10 @@ transform(props) {
16
16
  };
17
17
  }}
18
18
 
19
- export const getWrapStyle = (styles = {}) => wrapConfig.transform(styles, { map: mapObject })
19
+ export const getWrapStyle = (styles = {}) => {
20
+ const _styles = getPatternStyles(wrapConfig, styles)
21
+ return wrapConfig.transform(_styles, patternFns)
22
+ }
20
23
 
21
24
  export const wrap = (styles) => css(getWrapStyle(styles))
22
25
  wrap.raw = getWrapStyle
@@ -228,6 +228,30 @@ export interface Conditions {
228
228
  "lgTo2xl": string
229
229
  /** `@media screen and (min-width: 80em) and (max-width: 95.9975em)` */
230
230
  "xlTo2xl": string
231
+ /** `@container (min-width: 20em)` */
232
+ "@/xs": string
233
+ /** `@container (min-width: 24em)` */
234
+ "@/sm": string
235
+ /** `@container (min-width: 28em)` */
236
+ "@/md": string
237
+ /** `@container (min-width: 32em)` */
238
+ "@/lg": string
239
+ /** `@container (min-width: 36em)` */
240
+ "@/xl": string
241
+ /** `@container (min-width: 42em)` */
242
+ "@/2xl": string
243
+ /** `@container (min-width: 48em)` */
244
+ "@/3xl": string
245
+ /** `@container (min-width: 56em)` */
246
+ "@/4xl": string
247
+ /** `@container (min-width: 64em)` */
248
+ "@/5xl": string
249
+ /** `@container (min-width: 72em)` */
250
+ "@/6xl": string
251
+ /** `@container (min-width: 80em)` */
252
+ "@/7xl": string
253
+ /** `@container (min-width: 90em)` */
254
+ "@/8xl": string
231
255
  /** The base (=no conditions) styles to apply */
232
256
  "base": string
233
257
  }
@@ -13,13 +13,20 @@ export type PatternProperty =
13
13
 
14
14
  export interface PatternHelpers {
15
15
  map: (value: any, fn: (value: string) => string | undefined) => any
16
+ isCssUnit: (value: any) => boolean
17
+ isCssVar: (value: any) => boolean
18
+ isCssFunction: (value: any) => boolean
16
19
  }
17
20
 
18
21
  export interface PatternProperties {
19
22
  [key: string]: PatternProperty
20
23
  }
21
24
 
22
- type Props<T> = Record<LiteralUnion<keyof T>, any>
25
+ type InferProps<T> = Record<LiteralUnion<keyof T>, any>
26
+
27
+ export type PatternDefaultValue<T> = Partial<InferProps<T>>
28
+
29
+ export type PatternDefaultValueFn<T> = (props: InferProps<T>) => PatternDefaultValue<T>
23
30
 
24
31
  export interface PatternConfig<T extends PatternProperties = PatternProperties> {
25
32
  /**
@@ -35,10 +42,14 @@ export interface PatternConfig<T extends PatternProperties = PatternProperties>
35
42
  * The properties of the pattern.
36
43
  */
37
44
  properties?: T
45
+ /**
46
+ * The default values of the pattern.
47
+ */
48
+ defaultValues?: PatternDefaultValue<T> | PatternDefaultValueFn<T>
38
49
  /**
39
50
  * The css object this pattern will generate.
40
51
  */
41
- transform?: (props: Props<T>, helpers: PatternHelpers) => SystemStyleObject
52
+ transform?: (props: InferProps<T>, helpers: PatternHelpers) => SystemStyleObject
42
53
  /**
43
54
  * The jsx element name this pattern will generate.
44
55
  */
@@ -209,6 +209,7 @@ interface PropertyValueTypes {
209
209
  strokeWidth: Tokens["borderWidths"];
210
210
  srOnly: boolean;
211
211
  debug: boolean;
212
+ containerName: Tokens["containerNames"] | CssProperties["containerName"];
212
213
  colorPalette: "current" | "black" | "white" | "transparent" | "rose" | "pink" | "fuchsia" | "purple" | "violet" | "indigo" | "blue" | "sky" | "cyan" | "teal" | "emerald" | "green" | "lime" | "yellow" | "amber" | "orange" | "red" | "stone" | "zinc" | "gray" | "slate" | "neutral" | "text" | "bg" | "card" | "border" | "accent";
213
214
  textStyle: "xs" | "sm" | "md" | "lg" | "xl" | "2xl" | "3xl" | "4xl" | "5xl" | "6xl" | "7xl" | "8xl" | "9xl";
214
215
  }