@cutoff/audio-ui-react 1.0.0-preview.20260123.1125

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 (107) hide show
  1. package/LICENSE.md +690 -0
  2. package/README.md +228 -0
  3. package/dist/components/defaults/controls/Button.d.ts +51 -0
  4. package/dist/components/defaults/controls/Button.d.ts.map +1 -0
  5. package/dist/components/defaults/controls/ButtonView.d.ts +20 -0
  6. package/dist/components/defaults/controls/ButtonView.d.ts.map +1 -0
  7. package/dist/components/defaults/controls/CycleButton.d.ts +82 -0
  8. package/dist/components/defaults/controls/CycleButton.d.ts.map +1 -0
  9. package/dist/components/defaults/controls/Knob.d.ts +82 -0
  10. package/dist/components/defaults/controls/Knob.d.ts.map +1 -0
  11. package/dist/components/defaults/controls/KnobView.d.ts +43 -0
  12. package/dist/components/defaults/controls/KnobView.d.ts.map +1 -0
  13. package/dist/components/defaults/controls/Slider.d.ts +79 -0
  14. package/dist/components/defaults/controls/Slider.d.ts.map +1 -0
  15. package/dist/components/defaults/controls/SliderView.d.ts +90 -0
  16. package/dist/components/defaults/controls/SliderView.d.ts.map +1 -0
  17. package/dist/components/defaults/devices/Keys.d.ts +104 -0
  18. package/dist/components/defaults/devices/Keys.d.ts.map +1 -0
  19. package/dist/components/generic/controls/FilmStripBooleanControl.d.ts +58 -0
  20. package/dist/components/generic/controls/FilmStripBooleanControl.d.ts.map +1 -0
  21. package/dist/components/generic/controls/FilmStripContinuousControl.d.ts +82 -0
  22. package/dist/components/generic/controls/FilmStripContinuousControl.d.ts.map +1 -0
  23. package/dist/components/generic/controls/FilmStripDiscreteControl.d.ts +55 -0
  24. package/dist/components/generic/controls/FilmStripDiscreteControl.d.ts.map +1 -0
  25. package/dist/components/generic/controls/FilmstripView.d.ts +36 -0
  26. package/dist/components/generic/controls/FilmstripView.d.ts.map +1 -0
  27. package/dist/components/generic/controls/ImageKnob.d.ts +74 -0
  28. package/dist/components/generic/controls/ImageKnob.d.ts.map +1 -0
  29. package/dist/components/generic/controls/ImageKnobView.d.ts +38 -0
  30. package/dist/components/generic/controls/ImageKnobView.d.ts.map +1 -0
  31. package/dist/components/generic/controls/ImageRotarySwitch.d.ts +54 -0
  32. package/dist/components/generic/controls/ImageRotarySwitch.d.ts.map +1 -0
  33. package/dist/components/generic/controls/ImageSwitch.d.ts +62 -0
  34. package/dist/components/generic/controls/ImageSwitch.d.ts.map +1 -0
  35. package/dist/components/generic/controls/ImageSwitchView.d.ts +26 -0
  36. package/dist/components/generic/controls/ImageSwitchView.d.ts.map +1 -0
  37. package/dist/components/primitives/AdaptiveBox.d.ts +127 -0
  38. package/dist/components/primitives/AdaptiveBox.d.ts.map +1 -0
  39. package/dist/components/primitives/controls/BooleanControl.d.ts +66 -0
  40. package/dist/components/primitives/controls/BooleanControl.d.ts.map +1 -0
  41. package/dist/components/primitives/controls/ContinuousControl.d.ts +46 -0
  42. package/dist/components/primitives/controls/ContinuousControl.d.ts.map +1 -0
  43. package/dist/components/primitives/controls/DiscreteControl.d.ts +70 -0
  44. package/dist/components/primitives/controls/DiscreteControl.d.ts.map +1 -0
  45. package/dist/components/primitives/controls/OptionView.d.ts +12 -0
  46. package/dist/components/primitives/controls/OptionView.d.ts.map +1 -0
  47. package/dist/components/primitives/svg/FilmstripImage.d.ts +60 -0
  48. package/dist/components/primitives/svg/FilmstripImage.d.ts.map +1 -0
  49. package/dist/components/primitives/svg/Image.d.ts +50 -0
  50. package/dist/components/primitives/svg/Image.d.ts.map +1 -0
  51. package/dist/components/primitives/svg/LabelRing.d.ts +42 -0
  52. package/dist/components/primitives/svg/LabelRing.d.ts.map +1 -0
  53. package/dist/components/primitives/svg/LinearCursor.d.ts +72 -0
  54. package/dist/components/primitives/svg/LinearCursor.d.ts.map +1 -0
  55. package/dist/components/primitives/svg/LinearStrip.d.ts +49 -0
  56. package/dist/components/primitives/svg/LinearStrip.d.ts.map +1 -0
  57. package/dist/components/primitives/svg/RadialHtmlOverlay.d.ts +29 -0
  58. package/dist/components/primitives/svg/RadialHtmlOverlay.d.ts.map +1 -0
  59. package/dist/components/primitives/svg/RadialImage.d.ts +36 -0
  60. package/dist/components/primitives/svg/RadialImage.d.ts.map +1 -0
  61. package/dist/components/primitives/svg/RevealingPath.d.ts +37 -0
  62. package/dist/components/primitives/svg/RevealingPath.d.ts.map +1 -0
  63. package/dist/components/primitives/svg/RingArc.d.ts +21 -0
  64. package/dist/components/primitives/svg/RingArc.d.ts.map +1 -0
  65. package/dist/components/primitives/svg/RotaryImage.d.ts +43 -0
  66. package/dist/components/primitives/svg/RotaryImage.d.ts.map +1 -0
  67. package/dist/components/primitives/svg/TickRing.d.ts +53 -0
  68. package/dist/components/primitives/svg/TickRing.d.ts.map +1 -0
  69. package/dist/components/primitives/svg/ValueRing.d.ts +38 -0
  70. package/dist/components/primitives/svg/ValueRing.d.ts.map +1 -0
  71. package/dist/components/primitives/svg/ValueStrip.d.ts +59 -0
  72. package/dist/components/primitives/svg/ValueStrip.d.ts.map +1 -0
  73. package/dist/components/types.d.ts +451 -0
  74. package/dist/components/types.d.ts.map +1 -0
  75. package/dist/hooks/useAdaptiveSize.d.ts +32 -0
  76. package/dist/hooks/useAdaptiveSize.d.ts.map +1 -0
  77. package/dist/hooks/useArcAngle.d.ts +23 -0
  78. package/dist/hooks/useArcAngle.d.ts.map +1 -0
  79. package/dist/hooks/useAudioParameter.d.ts +89 -0
  80. package/dist/hooks/useAudioParameter.d.ts.map +1 -0
  81. package/dist/hooks/useBooleanInteraction.d.ts +106 -0
  82. package/dist/hooks/useBooleanInteraction.d.ts.map +1 -0
  83. package/dist/hooks/useBooleanParameterResolution.d.ts +54 -0
  84. package/dist/hooks/useBooleanParameterResolution.d.ts.map +1 -0
  85. package/dist/hooks/useContinuousInteraction.d.ts +94 -0
  86. package/dist/hooks/useContinuousInteraction.d.ts.map +1 -0
  87. package/dist/hooks/useContinuousParameterResolution.d.ts +75 -0
  88. package/dist/hooks/useContinuousParameterResolution.d.ts.map +1 -0
  89. package/dist/hooks/useDiscreteInteraction.d.ts +70 -0
  90. package/dist/hooks/useDiscreteInteraction.d.ts.map +1 -0
  91. package/dist/hooks/useDiscreteParameterResolution.d.ts +120 -0
  92. package/dist/hooks/useDiscreteParameterResolution.d.ts.map +1 -0
  93. package/dist/hooks/useNoteInteraction.d.ts +84 -0
  94. package/dist/hooks/useNoteInteraction.d.ts.map +1 -0
  95. package/dist/hooks/useThemableProps.d.ts +68 -0
  96. package/dist/hooks/useThemableProps.d.ts.map +1 -0
  97. package/dist/index.d.ts +77 -0
  98. package/dist/index.d.ts.map +1 -0
  99. package/dist/index.js +3197 -0
  100. package/dist/index.js.map +1 -0
  101. package/dist/stats.html +4949 -0
  102. package/dist/style.css +1 -0
  103. package/dist/utils/textUtils.d.ts +15 -0
  104. package/dist/utils/textUtils.d.ts.map +1 -0
  105. package/dist/utils/theme.d.ts +88 -0
  106. package/dist/utils/theme.d.ts.map +1 -0
  107. package/package.json +78 -0
package/dist/style.css ADDED
@@ -0,0 +1 @@
1
+ :root{--audioui-roundness-base: .3;--audioui-primary-color: var(--audioui-adaptive-default-color);--audioui-nearwhite: hsl(0, 0%, 96%);--audioui-nearblack: hsl(0, 0%, 10%);--audioui-theme-blue: hsl(204, 88%, 52%);--audioui-theme-orange: hsl(29, 100%, 48%);--audioui-theme-pink: hsl(332, 92%, 52%);--audioui-theme-green: hsl(160, 95%, 44%);--audioui-theme-purple: hsl(252, 96%, 54%);--audioui-theme-yellow: hsl(50, 100%, 50%);--audioui-theme-default: var(--audioui-nearblack);--audioui-adaptive-default-color: var(--audioui-theme-default);--audioui-adaptive-50: color-mix(in srgb, var(--audioui-adaptive-default-color) 50%, transparent);--audioui-adaptive-20: color-mix(in srgb, var(--audioui-adaptive-default-color) 20%, transparent);--audioui-adaptive-light: color-mix(in srgb, var(--audioui-adaptive-default-color) 80%, white);--audioui-adaptive-dark: color-mix(in srgb, var(--audioui-adaptive-default-color) 80%, black);--audioui-primary-50: color-mix(in srgb, var(--audioui-primary-color) 50%, transparent);--audioui-primary-20: color-mix(in srgb, var(--audioui-primary-color) 20%, transparent);--audioui-primary-light: color-mix(in srgb, var(--audioui-primary-color) 80%, white);--audioui-primary-dark: color-mix(in srgb, var(--audioui-primary-color) 80%, black);--audioui-text-color: var(--audioui-nearblack);--audioui-default-font-size: 14px;--audioui-highlight-effect: brightness(1.15) contrast(1.05) drop-shadow( 0 0 .5em color-mix(in srgb, var(--audioui-primary-color, var(--audioui-text-color)) 35%, transparent) );--audioui-highlight-transition-duration: 50ms;--audioui-cursor-clickable: pointer;--audioui-cursor-bidirectional: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzIiIGhlaWdodD0iMzIiIHZpZXdCb3g9IjAgMCAzMiAzMiIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48cGF0aCBkPSJNMTYgN3YxOE03IDE2aDE4TTE2IDdsLTQgNE0xNiA3bDQgNE0xNiAyNWwtNC00TTE2IDI1bDQtNE03IDE2bDQtNE03IDE2bDQgNE0yNSAxNmwtNC00TTI1IDE2bC00IDQiIHN0cm9rZT0id2hpdGUiIHN0cm9rZS13aWR0aD0iNCIgc3Ryb2tlLWxpbmVjYXA9InJvdW5kIiBzdHJva2UtbGluZWpvaW49InJvdW5kIi8+PHBhdGggZD0iTTE2IDd2MThNNyAxNmgxOE0xNiA3bC00IDRNMTYgN2w0IDRNMTYgMjVsLTQtNE0xNiAyNWw0LTRNNyAxNmw0LTRNNyAxNmw0IDRNMjUgMTZsLTQtNE0yNSAxNmwtNCA0IiBzdHJva2U9ImJsYWNrIiBzdHJva2Utd2lkdGg9IjIiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCIvPjwvc3ZnPg==) 16 16, move;--audioui-cursor-horizontal: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzIiIGhlaWdodD0iMzIiIHZpZXdCb3g9IjAgMCAzMiAzMiIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48cGF0aCBkPSJNNyAxNmgxOE03IDE2bDUtNU03IDE2bDUgNU0yNSAxNmwtNS01TTI1IDE2bC01IDUiIHN0cm9rZT0id2hpdGUiIHN0cm9rZS13aWR0aD0iNCIgc3Ryb2tlLWxpbmVjYXA9InJvdW5kIiBzdHJva2UtbGluZWpvaW49InJvdW5kIi8+PHBhdGggZD0iTTcgMTZoMThNNyAxNmw1LTVNNyAxNmw1IDVNMjUgMTZsLTUtNU0yNSAxNmwtNSA1IiBzdHJva2U9ImJsYWNrIiBzdHJva2Utd2lkdGg9IjIiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCIvPjwvc3ZnPg==) 16 16, ew-resize;--audioui-cursor-vertical: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzIiIGhlaWdodD0iMzIiIHZpZXdCb3g9IjAgMCAzMiAzMiIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48cGF0aCBkPSJNMTYgN3YxOE0xNiA3bC01IDVNMTYgN2w1IDVNMTYgMjVsLTUtNU0xNiAyNWw1LTUiIHN0cm9rZT0id2hpdGUiIHN0cm9rZS13aWR0aD0iNCIgc3Ryb2tlLWxpbmVjYXA9InJvdW5kIiBzdHJva2UtbGluZWpvaW49InJvdW5kIi8+PHBhdGggZD0iTTE2IDd2MThNMTYgN2wtNSA1TTE2IDdsNSA1TTE2IDI1bC01LTVNMTYgMjVsNS01IiBzdHJva2U9ImJsYWNrIiBzdHJva2Utd2lkdGg9IjIiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCIvPjwvc3ZnPg==) 16 16, ns-resize;--audioui-cursor-circular: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzIiIGhlaWdodD0iMzIiIHZpZXdCb3g9IjAgMCAzMiAzMiIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48Y2lyY2xlIGN4PSIxNiIgY3k9IjE2IiByPSIxMCIgc3Ryb2tlPSJ3aGl0ZSIgc3Ryb2tlLXdpZHRoPSI0Ii8+PGNpcmNsZSBjeD0iMTYiIGN5PSIxNiIgcj0iMTAiIHN0cm9rZT0iYmxhY2siIHN0cm9rZS13aWR0aD0iMiIvPjwvc3ZnPg==) 16 16, move;--audioui-cursor-noneditable: default;--audioui-cursor-disabled: not-allowed;--audioui-keys-ivory: hsl(40, 20%, 95%);--audioui-keys-ivory-stroke: hsl(40, 20%, 85%);--audioui-keys-ebony: hsl(0, 0%, 15%);--audioui-keys-ebony-stroke: hsl(0, 0%, 25%);--audioui-knob-cap-fill: #303030;--audioui-button-stroke-width: 5px;--audioui-slider-track-color: var( --audioui-adaptive-20 );--audioui-slider-strip-color: var(--audioui-primary-color);--audioui-slider-cursor-color: var(--audioui-primary-color);--audioui-slider-cursor-border-color: var( --audioui-primary-light );--audioui-slider-cursor-border-width: 5px;--audioui-roundness-button: calc(var(--audioui-roundness-base) * 50px);--audioui-roundness-knob: var(--audioui-roundness-base);--audioui-roundness-slider: calc(var(--audioui-roundness-base) * 20px);--audioui-roundness-keys: calc(var(--audioui-roundness-base) * 12px);--audioui-linecap-base: round;--audioui-linecap-knob: var(--audioui-linecap-base);--audioui-linecap-slider: var(--audioui-linecap-base);--audioui-linecap-button: var(--audioui-linecap-base);--audioui-unit: 48px;--audioui-size-mult-xsmall: 1;--audioui-size-mult-small: 1.25;--audioui-size-mult-normal: 1.5;--audioui-size-mult-large: 2;--audioui-size-mult-xlarge: 2.5;--audioui-size-square-xsmall: var(--audioui-unit);--audioui-size-square-small: calc(var(--audioui-unit) * var(--audioui-size-mult-small));--audioui-size-square-normal: calc(var(--audioui-unit) * var(--audioui-size-mult-normal));--audioui-size-square-large: calc(var(--audioui-unit) * var(--audioui-size-mult-large));--audioui-size-square-xlarge: calc(var(--audioui-unit) * var(--audioui-size-mult-xlarge));--audioui-size-hslider-height-xsmall: var(--audioui-unit);--audioui-size-hslider-height-small: calc(var(--audioui-unit) * var(--audioui-size-mult-small));--audioui-size-hslider-height-normal: calc(var(--audioui-unit) * var(--audioui-size-mult-normal));--audioui-size-hslider-height-large: calc(var(--audioui-unit) * var(--audioui-size-mult-large));--audioui-size-hslider-height-xlarge: calc(var(--audioui-unit) * var(--audioui-size-mult-xlarge));--audioui-size-hslider-width-xsmall: calc(var(--audioui-size-hslider-height-xsmall) * 2);--audioui-size-hslider-width-small: calc(var(--audioui-size-hslider-height-small) * 2);--audioui-size-hslider-width-normal: calc(var(--audioui-size-hslider-height-normal) * 2);--audioui-size-hslider-width-large: calc(var(--audioui-size-hslider-height-large) * 2);--audioui-size-hslider-width-xlarge: calc(var(--audioui-size-hslider-height-xlarge) * 2);--audioui-size-vslider-width-xsmall: var(--audioui-unit);--audioui-size-vslider-width-small: calc(var(--audioui-unit) * var(--audioui-size-mult-small));--audioui-size-vslider-width-normal: calc(var(--audioui-unit) * var(--audioui-size-mult-normal));--audioui-size-vslider-width-large: calc(var(--audioui-unit) * var(--audioui-size-mult-large));--audioui-size-vslider-width-xlarge: calc(var(--audioui-unit) * var(--audioui-size-mult-xlarge));--audioui-size-vslider-height-xsmall: calc(var(--audioui-size-vslider-width-xsmall) * 2);--audioui-size-vslider-height-small: calc(var(--audioui-size-vslider-width-small) * 2);--audioui-size-vslider-height-normal: calc(var(--audioui-size-vslider-width-normal) * 2);--audioui-size-vslider-height-large: calc(var(--audioui-size-vslider-width-large) * 2);--audioui-size-vslider-height-xlarge: calc(var(--audioui-size-vslider-width-xlarge) * 2);--audioui-size-keys-height-xsmall: var(--audioui-unit);--audioui-size-keys-height-small: calc(var(--audioui-unit) * var(--audioui-size-mult-small));--audioui-size-keys-height-normal: calc(var(--audioui-unit) * var(--audioui-size-mult-normal));--audioui-size-keys-height-large: calc(var(--audioui-unit) * var(--audioui-size-mult-large));--audioui-size-keys-height-xlarge: calc(var(--audioui-unit) * var(--audioui-size-mult-xlarge));--audioui-size-keys-width-xsmall: calc(var(--audioui-size-keys-height-xsmall) * 5);--audioui-size-keys-width-small: calc(var(--audioui-size-keys-height-small) * 5);--audioui-size-keys-width-normal: calc(var(--audioui-size-keys-height-normal) * 5);--audioui-size-keys-width-large: calc(var(--audioui-size-keys-height-large) * 5);--audioui-size-keys-width-xlarge: calc(var(--audioui-size-keys-height-xlarge) * 5)}.dark{--audioui-theme-default: var(--audioui-nearwhite);--audioui-adaptive-default-color: var(--audioui-theme-default);--audioui-theme-blue: hsl(204, 88%, 53%);--audioui-theme-orange: hsl(29, 100%, 50%);--audioui-theme-pink: hsl(332, 95%, 54%);--audioui-theme-green: hsl(160, 98%, 37%);--audioui-theme-purple: hsl(252, 100%, 67%);--audioui-theme-yellow: hsl(50, 100%, 50%);--audioui-text-color: var(--audioui-nearwhite);--audioui-knob-cap-fill: #4a4d50;--audioui-slider-cursor-border-color: var( --audioui-primary-dark )}textarea,input{color:var(--audioui-text-color);background-color:transparent;font-size:var(--audioui-default-font-size)}svg text,svg foreignObject div{-webkit-user-select:none;user-select:none;cursor:default}svg foreignObject div svg{fill:currentColor;color:inherit;max-width:75%;max-height:75%}.audioui-icon-wrapper{display:flex;align-items:center;justify-content:center}.audioui-icon-wrapper svg{width:100%;height:100%;fill:currentColor;color:inherit}.audioui{-webkit-user-select:none;user-select:none;cursor:default}.audioui-component-container{height:auto;max-width:100%;max-height:100%}.audioui-component-container svg{height:auto;outline:none}.audioui-highlight{will-change:filter;transition:filter var(--audioui-highlight-transition-duration) linear}.audioui-highlight:hover,.audioui-highlight:focus,.audioui-highlight:focus-visible{filter:var(--audioui-highlight-effect);outline:none}.audioui-highlight text{isolation:isolate}.audioui-highlight foreignObject{isolation:isolate}.audioui-stroke-primary{stroke:var(--audioui-primary-color)}.audioui-fill-text{fill:var(--audioui-text-color)}.audioui-fill-primary{fill:var(--audioui-primary-color)}.audioui-fill-transparent{fill:transparent}.audioui-border-primary{border-color:var(--audioui-primary-color)}.audioui-text-primary{color:var(--audioui-primary-color)}.audioui-size-square-xsmall{width:var(--audioui-size-square-xsmall);height:var(--audioui-size-square-xsmall)}.audioui-size-square-small{width:var(--audioui-size-square-small);height:var(--audioui-size-square-small)}.audioui-size-square-normal{width:var(--audioui-size-square-normal);height:var(--audioui-size-square-normal)}.audioui-size-square-large{width:var(--audioui-size-square-large);height:var(--audioui-size-square-large)}.audioui-size-square-xlarge{width:var(--audioui-size-square-xlarge);height:var(--audioui-size-square-xlarge)}.audioui-size-hslider-xsmall{width:var(--audioui-size-hslider-width-xsmall);height:var(--audioui-size-hslider-height-xsmall)}.audioui-size-hslider-small{width:var(--audioui-size-hslider-width-small);height:var(--audioui-size-hslider-height-small)}.audioui-size-hslider-normal{width:var(--audioui-size-hslider-width-normal);height:var(--audioui-size-hslider-height-normal)}.audioui-size-hslider-large{width:var(--audioui-size-hslider-width-large);height:var(--audioui-size-hslider-height-large)}.audioui-size-hslider-xlarge{width:var(--audioui-size-hslider-width-xlarge);height:var(--audioui-size-hslider-height-xlarge)}.audioui-size-vslider-xsmall{width:var(--audioui-size-vslider-width-xsmall);height:var(--audioui-size-vslider-height-xsmall)}.audioui-size-vslider-small{width:var(--audioui-size-vslider-width-small);height:var(--audioui-size-vslider-height-small)}.audioui-size-vslider-normal{width:var(--audioui-size-vslider-width-normal);height:var(--audioui-size-vslider-height-normal)}.audioui-size-vslider-large{width:var(--audioui-size-vslider-width-large);height:var(--audioui-size-vslider-height-large)}.audioui-size-vslider-xlarge{width:var(--audioui-size-vslider-width-xlarge);height:var(--audioui-size-vslider-height-xlarge)}.audioui-size-keys-xsmall{width:var(--audioui-size-keys-width-xsmall);height:var(--audioui-size-keys-height-xsmall)}.audioui-size-keys-small{width:var(--audioui-size-keys-width-small);height:var(--audioui-size-keys-height-small)}.audioui-size-keys-normal{width:var(--audioui-size-keys-width-normal);height:var(--audioui-size-keys-height-normal)}.audioui-size-keys-large{width:var(--audioui-size-keys-width-large);height:var(--audioui-size-keys-height-large)}.audioui-size-keys-xlarge{width:var(--audioui-size-keys-width-xlarge);height:var(--audioui-size-keys-height-xlarge)}
@@ -0,0 +1,15 @@
1
+ /**
2
+ * Abbreviates text to a maximum number of characters.
3
+ * Returns the first N characters of the text, or the original text if it's shorter.
4
+ *
5
+ * @param text - The text to abbreviate
6
+ * @param maxLength - Maximum length (default: 3)
7
+ * @returns Abbreviated text
8
+ *
9
+ * @example
10
+ * abbreviateText("Volume", 3) // "Vol"
11
+ * abbreviateText("Hi", 3) // "Hi"
12
+ * abbreviateText("", 3) // ""
13
+ */
14
+ export declare function abbreviateText(text: string, maxLength?: number): string;
15
+ //# sourceMappingURL=textUtils.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"textUtils.d.ts","sourceRoot":"","sources":["../../src/utils/textUtils.ts"],"names":[],"mappings":"AAMA;;;;;;;;;;;;GAYG;AACH,wBAAgB,cAAc,CAAC,IAAI,EAAE,MAAM,EAAE,SAAS,GAAE,MAAU,GAAG,MAAM,CAK1E"}
@@ -0,0 +1,88 @@
1
+ /**
2
+ * Set the global theme color.
3
+ * Updates the CSS variable `--audioui-primary-color` on the document root.
4
+ * Color variants (`--audioui-primary-50`, `--audioui-primary-20`) are automatically computed
5
+ * by CSS using `color-mix()`.
6
+ *
7
+ * @param color - Any valid CSS color value (e.g., "blue", "#FF5500", "hsl(200, 100%, 50%)", "var(--my-color)")
8
+ *
9
+ * @example
10
+ * ```ts
11
+ * setThemeColor("blue");
12
+ * setThemeColor("var(--audioui-theme-purple)");
13
+ * setThemeColor("hsl(200, 100%, 50%)");
14
+ * ```
15
+ */
16
+ export declare function setThemeColor(color: string): void;
17
+ /**
18
+ * Set the global theme roundness.
19
+ * Updates the CSS variable `--audioui-roundness-base` on the document root.
20
+ * Component-specific roundness values are automatically calculated from this base value.
21
+ *
22
+ * This function also updates the `--audioui-linecap-base` helper variable:
23
+ * - value = 0.0 results in "square"
24
+ * - value > 0.0 results in "round"
25
+ *
26
+ * @param value - Normalized roundness value between 0.0 and 1.0
27
+ *
28
+ * @example
29
+ * ```ts
30
+ * setThemeRoundness(0.3); // 30% roundness, linecap: round
31
+ * setThemeRoundness(0.0); // Square corners, linecap: square
32
+ * setThemeRoundness(1.0); // Maximum roundness, linecap: round
33
+ * ```
34
+ */
35
+ export declare function setThemeRoundness(value: number): void;
36
+ /**
37
+ * Theme configuration object for setting multiple theme values at once.
38
+ */
39
+ export interface ThemeConfig {
40
+ /** Theme color - any valid CSS color value */
41
+ color?: string;
42
+ /** Roundness (normalized 0.0-1.0) */
43
+ roundness?: number;
44
+ }
45
+ /**
46
+ * Set multiple theme values at once.
47
+ * Convenience function that calls individual setter functions for each provided value.
48
+ *
49
+ * @param theme - Theme configuration object with optional color and roundness values
50
+ *
51
+ * @example
52
+ * ```ts
53
+ * setTheme({ color: "blue", roundness: 0.3 });
54
+ * setTheme({ color: "purple" }); // Only sets color, leaves roundness unchanged
55
+ * ```
56
+ */
57
+ export declare function setTheme(theme: ThemeConfig): void;
58
+ /**
59
+ * Get current theme color from CSS variable.
60
+ * Reads the value of `--audioui-primary-color` from the document root.
61
+ *
62
+ * @returns The current theme color value as a string, or `null` if not set or in SSR context
63
+ *
64
+ * @example
65
+ * ```ts
66
+ * const currentColor = getThemeColor();
67
+ * if (currentColor) {
68
+ * console.log(`Current theme color: ${currentColor}`);
69
+ * }
70
+ * ```
71
+ */
72
+ export declare function getThemeColor(): string | null;
73
+ /**
74
+ * Get current theme roundness from CSS variable.
75
+ * Reads the value of `--audioui-roundness-base` from the document root.
76
+ *
77
+ * @returns The current theme roundness value as a number (0.0-1.0), or `null` if not set or in SSR context
78
+ *
79
+ * @example
80
+ * ```ts
81
+ * const roundness = getThemeRoundness();
82
+ * if (roundness !== null) {
83
+ * console.log(`Current roundness: ${roundness * 100}%`);
84
+ * }
85
+ * ```
86
+ */
87
+ export declare function getThemeRoundness(): number | null;
88
+ //# sourceMappingURL=theme.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"theme.d.ts","sourceRoot":"","sources":["../../src/utils/theme.ts"],"names":[],"mappings":"AAMA;;;;;;;;;;;;;;GAcG;AACH,wBAAgB,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAIjD;AAED;;;;;;;;;;;;;;;;;GAiBG;AACH,wBAAgB,iBAAiB,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAOrD;AAED;;GAEG;AACH,MAAM,WAAW,WAAW;IACxB,8CAA8C;IAC9C,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,qCAAqC;IACrC,SAAS,CAAC,EAAE,MAAM,CAAC;CACtB;AAED;;;;;;;;;;;GAWG;AACH,wBAAgB,QAAQ,CAAC,KAAK,EAAE,WAAW,GAAG,IAAI,CASjD;AAED;;;;;;;;;;;;;GAaG;AACH,wBAAgB,aAAa,IAAI,MAAM,GAAG,IAAI,CAG7C;AAED;;;;;;;;;;;;;GAaG;AACH,wBAAgB,iBAAiB,IAAI,MAAM,GAAG,IAAI,CAIjD"}
package/package.json ADDED
@@ -0,0 +1,78 @@
1
+ {
2
+ "name": "@cutoff/audio-ui-react",
3
+ "description": "AudioUI by Cutoff - React Components for Audio and MIDI apps! Dual-licensed: GPL-3.0 for open source, Commercial for proprietary use.",
4
+ "version": "1.0.0-preview.20260123.1125",
5
+ "private": false,
6
+ "author": "Renaud Denis <mail@renauddenis.com> (https://renauddenis.com)",
7
+ "license": "GPL-3.0-only",
8
+ "homepage": "https://cutoff.dev",
9
+ "repository": {
10
+ "type": "git",
11
+ "url": "git+https://github.com/cutoff/audio-ui.git",
12
+ "directory": "packages/react"
13
+ },
14
+ "bugs": {
15
+ "url": "https://github.com/cutoff/audio-ui/issues"
16
+ },
17
+ "publishConfig": {
18
+ "access": "public"
19
+ },
20
+ "type": "module",
21
+ "main": "dist/index.js",
22
+ "types": "dist/index.d.ts",
23
+ "sideEffects": [
24
+ "**/*.css"
25
+ ],
26
+ "exports": {
27
+ ".": {
28
+ "import": "./dist/index.js",
29
+ "types": "./dist/index.d.ts"
30
+ },
31
+ "./style.css": "./dist/style.css"
32
+ },
33
+ "files": [
34
+ "dist"
35
+ ],
36
+ "keywords": [
37
+ "react",
38
+ "audio",
39
+ "midi",
40
+ "components"
41
+ ],
42
+ "peerDependencies": {
43
+ "react": "^18.2.0",
44
+ "react-dom": "^18.2.0"
45
+ },
46
+ "dependencies": {
47
+ "classnames": "^2.5.1",
48
+ "fast-deep-equal": "^3.1.3",
49
+ "@cutoff/audio-ui-core": "1.0.0-preview.20260123.1125"
50
+ },
51
+ "devDependencies": {
52
+ "@testing-library/dom": "^10.4.1",
53
+ "@testing-library/react": "^16.3.0",
54
+ "@types/react": "^18.3.27",
55
+ "@types/react-dom": "^18.3.7",
56
+ "@vitejs/plugin-react-swc": "^3.11.0",
57
+ "@vitest/coverage-v8": "^1.6.1",
58
+ "jsdom": "^24.1.3",
59
+ "stylelint": "^16.26.1",
60
+ "typescript": "^5.9.3",
61
+ "vite": "^5.4.21",
62
+ "rollup-plugin-visualizer": "^5.12.0",
63
+ "vite-plugin-dts": "^3.9.1",
64
+ "vitest": "^1.6.1"
65
+ },
66
+ "scripts": {
67
+ "clean": "rm -rf node_modules dist .turbo",
68
+ "build": "pnpm exec vite build",
69
+ "typecheck": "tsc --noEmit",
70
+ "test": "vitest run",
71
+ "test:watch": "vitest",
72
+ "test:coverage": "vitest run --coverage",
73
+ "lint": "eslint \"src/**/*.{ts,tsx}\"",
74
+ "lint:fix": "eslint \"src/**/*.{ts,tsx}\" --fix || true",
75
+ "lint:css": "stylelint \"src/**/*.css\"",
76
+ "analyze": "pnpm build"
77
+ }
78
+ }