@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.
- package/LICENSE.md +690 -0
- package/README.md +228 -0
- package/dist/components/defaults/controls/Button.d.ts +51 -0
- package/dist/components/defaults/controls/Button.d.ts.map +1 -0
- package/dist/components/defaults/controls/ButtonView.d.ts +20 -0
- package/dist/components/defaults/controls/ButtonView.d.ts.map +1 -0
- package/dist/components/defaults/controls/CycleButton.d.ts +82 -0
- package/dist/components/defaults/controls/CycleButton.d.ts.map +1 -0
- package/dist/components/defaults/controls/Knob.d.ts +82 -0
- package/dist/components/defaults/controls/Knob.d.ts.map +1 -0
- package/dist/components/defaults/controls/KnobView.d.ts +43 -0
- package/dist/components/defaults/controls/KnobView.d.ts.map +1 -0
- package/dist/components/defaults/controls/Slider.d.ts +79 -0
- package/dist/components/defaults/controls/Slider.d.ts.map +1 -0
- package/dist/components/defaults/controls/SliderView.d.ts +90 -0
- package/dist/components/defaults/controls/SliderView.d.ts.map +1 -0
- package/dist/components/defaults/devices/Keys.d.ts +104 -0
- package/dist/components/defaults/devices/Keys.d.ts.map +1 -0
- package/dist/components/generic/controls/FilmStripBooleanControl.d.ts +58 -0
- package/dist/components/generic/controls/FilmStripBooleanControl.d.ts.map +1 -0
- package/dist/components/generic/controls/FilmStripContinuousControl.d.ts +82 -0
- package/dist/components/generic/controls/FilmStripContinuousControl.d.ts.map +1 -0
- package/dist/components/generic/controls/FilmStripDiscreteControl.d.ts +55 -0
- package/dist/components/generic/controls/FilmStripDiscreteControl.d.ts.map +1 -0
- package/dist/components/generic/controls/FilmstripView.d.ts +36 -0
- package/dist/components/generic/controls/FilmstripView.d.ts.map +1 -0
- package/dist/components/generic/controls/ImageKnob.d.ts +74 -0
- package/dist/components/generic/controls/ImageKnob.d.ts.map +1 -0
- package/dist/components/generic/controls/ImageKnobView.d.ts +38 -0
- package/dist/components/generic/controls/ImageKnobView.d.ts.map +1 -0
- package/dist/components/generic/controls/ImageRotarySwitch.d.ts +54 -0
- package/dist/components/generic/controls/ImageRotarySwitch.d.ts.map +1 -0
- package/dist/components/generic/controls/ImageSwitch.d.ts +62 -0
- package/dist/components/generic/controls/ImageSwitch.d.ts.map +1 -0
- package/dist/components/generic/controls/ImageSwitchView.d.ts +26 -0
- package/dist/components/generic/controls/ImageSwitchView.d.ts.map +1 -0
- package/dist/components/primitives/AdaptiveBox.d.ts +127 -0
- package/dist/components/primitives/AdaptiveBox.d.ts.map +1 -0
- package/dist/components/primitives/controls/BooleanControl.d.ts +66 -0
- package/dist/components/primitives/controls/BooleanControl.d.ts.map +1 -0
- package/dist/components/primitives/controls/ContinuousControl.d.ts +46 -0
- package/dist/components/primitives/controls/ContinuousControl.d.ts.map +1 -0
- package/dist/components/primitives/controls/DiscreteControl.d.ts +70 -0
- package/dist/components/primitives/controls/DiscreteControl.d.ts.map +1 -0
- package/dist/components/primitives/controls/OptionView.d.ts +12 -0
- package/dist/components/primitives/controls/OptionView.d.ts.map +1 -0
- package/dist/components/primitives/svg/FilmstripImage.d.ts +60 -0
- package/dist/components/primitives/svg/FilmstripImage.d.ts.map +1 -0
- package/dist/components/primitives/svg/Image.d.ts +50 -0
- package/dist/components/primitives/svg/Image.d.ts.map +1 -0
- package/dist/components/primitives/svg/LabelRing.d.ts +42 -0
- package/dist/components/primitives/svg/LabelRing.d.ts.map +1 -0
- package/dist/components/primitives/svg/LinearCursor.d.ts +72 -0
- package/dist/components/primitives/svg/LinearCursor.d.ts.map +1 -0
- package/dist/components/primitives/svg/LinearStrip.d.ts +49 -0
- package/dist/components/primitives/svg/LinearStrip.d.ts.map +1 -0
- package/dist/components/primitives/svg/RadialHtmlOverlay.d.ts +29 -0
- package/dist/components/primitives/svg/RadialHtmlOverlay.d.ts.map +1 -0
- package/dist/components/primitives/svg/RadialImage.d.ts +36 -0
- package/dist/components/primitives/svg/RadialImage.d.ts.map +1 -0
- package/dist/components/primitives/svg/RevealingPath.d.ts +37 -0
- package/dist/components/primitives/svg/RevealingPath.d.ts.map +1 -0
- package/dist/components/primitives/svg/RingArc.d.ts +21 -0
- package/dist/components/primitives/svg/RingArc.d.ts.map +1 -0
- package/dist/components/primitives/svg/RotaryImage.d.ts +43 -0
- package/dist/components/primitives/svg/RotaryImage.d.ts.map +1 -0
- package/dist/components/primitives/svg/TickRing.d.ts +53 -0
- package/dist/components/primitives/svg/TickRing.d.ts.map +1 -0
- package/dist/components/primitives/svg/ValueRing.d.ts +38 -0
- package/dist/components/primitives/svg/ValueRing.d.ts.map +1 -0
- package/dist/components/primitives/svg/ValueStrip.d.ts +59 -0
- package/dist/components/primitives/svg/ValueStrip.d.ts.map +1 -0
- package/dist/components/types.d.ts +451 -0
- package/dist/components/types.d.ts.map +1 -0
- package/dist/hooks/useAdaptiveSize.d.ts +32 -0
- package/dist/hooks/useAdaptiveSize.d.ts.map +1 -0
- package/dist/hooks/useArcAngle.d.ts +23 -0
- package/dist/hooks/useArcAngle.d.ts.map +1 -0
- package/dist/hooks/useAudioParameter.d.ts +89 -0
- package/dist/hooks/useAudioParameter.d.ts.map +1 -0
- package/dist/hooks/useBooleanInteraction.d.ts +106 -0
- package/dist/hooks/useBooleanInteraction.d.ts.map +1 -0
- package/dist/hooks/useBooleanParameterResolution.d.ts +54 -0
- package/dist/hooks/useBooleanParameterResolution.d.ts.map +1 -0
- package/dist/hooks/useContinuousInteraction.d.ts +94 -0
- package/dist/hooks/useContinuousInteraction.d.ts.map +1 -0
- package/dist/hooks/useContinuousParameterResolution.d.ts +75 -0
- package/dist/hooks/useContinuousParameterResolution.d.ts.map +1 -0
- package/dist/hooks/useDiscreteInteraction.d.ts +70 -0
- package/dist/hooks/useDiscreteInteraction.d.ts.map +1 -0
- package/dist/hooks/useDiscreteParameterResolution.d.ts +120 -0
- package/dist/hooks/useDiscreteParameterResolution.d.ts.map +1 -0
- package/dist/hooks/useNoteInteraction.d.ts +84 -0
- package/dist/hooks/useNoteInteraction.d.ts.map +1 -0
- package/dist/hooks/useThemableProps.d.ts +68 -0
- package/dist/hooks/useThemableProps.d.ts.map +1 -0
- package/dist/index.d.ts +77 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +3197 -0
- package/dist/index.js.map +1 -0
- package/dist/stats.html +4949 -0
- package/dist/style.css +1 -0
- package/dist/utils/textUtils.d.ts +15 -0
- package/dist/utils/textUtils.d.ts.map +1 -0
- package/dist/utils/theme.d.ts +88 -0
- package/dist/utils/theme.d.ts.map +1 -0
- 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
|
+
}
|