@jadujoel/web-audio-clip-node 0.1.0 → 0.1.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (346) hide show
  1. package/README.md +9 -3
  2. package/dist/audio/ClipNode.js +312 -0
  3. package/dist/audio/processor-code.js +2 -0
  4. package/dist/audio/processor-kernel.js +861 -0
  5. package/dist/audio/processor.js +80 -0
  6. package/dist/audio/types.js +9 -0
  7. package/dist/audio/utils.js +128 -0
  8. package/dist/audio/version.d.ts +1 -0
  9. package/dist/audio/version.js +2 -0
  10. package/dist/audio/workletUrl.js +17 -0
  11. package/dist/components/AudioControl.js +99 -0
  12. package/dist/components/ContextMenu.js +73 -0
  13. package/dist/components/ControlSection.js +74 -0
  14. package/dist/components/DetuneControl.js +44 -0
  15. package/dist/components/DisplayPanel.js +6 -0
  16. package/dist/components/FilterControl.js +48 -0
  17. package/dist/components/GainControl.js +44 -0
  18. package/dist/components/PanControl.js +50 -0
  19. package/dist/components/PlaybackRateControl.js +44 -0
  20. package/dist/components/PlayheadSlider.js +20 -0
  21. package/dist/components/SnappableSlider.js +174 -0
  22. package/dist/components/TransportButtons.js +9 -0
  23. package/dist/controls/controlDefs.js +211 -0
  24. package/dist/controls/formatValueText.js +80 -0
  25. package/dist/controls/linkedControlPairs.js +51 -0
  26. package/dist/data/cache.js +17 -0
  27. package/dist/data/fileStore.js +39 -0
  28. package/dist/hooks/useClipNode.js +338 -0
  29. package/dist/lib-react.js +17 -19
  30. package/dist/lib.bundle.js +6 -0
  31. package/dist/lib.bundle.js.map +7 -0
  32. package/dist/lib.js +16 -44
  33. package/dist/store/clipStore.js +71 -0
  34. package/examples/README.md +10 -0
  35. package/examples/cdn-vanilla/README.md +13 -0
  36. package/examples/cdn-vanilla/index.html +69 -0
  37. package/examples/esm-bundler/README.md +8 -0
  38. package/examples/esm-bundler/index.html +12 -0
  39. package/examples/esm-bundler/node_modules/.package-lock.json +1168 -0
  40. package/examples/esm-bundler/node_modules/@esbuild/darwin-arm64/README.md +3 -0
  41. package/examples/esm-bundler/node_modules/@esbuild/darwin-arm64/bin/esbuild +0 -0
  42. package/examples/esm-bundler/node_modules/@esbuild/darwin-arm64/package.json +20 -0
  43. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/LICENSE +21 -0
  44. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/README.md +91 -0
  45. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/ClipNode.d.ts +86 -0
  46. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/ClipNode.js +312 -0
  47. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/processor-code.d.ts +1 -0
  48. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/processor-code.js +2 -0
  49. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/processor-kernel.d.ts +43 -0
  50. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/processor-kernel.js +861 -0
  51. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/processor.d.ts +1 -0
  52. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/processor.js +80 -0
  53. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/types.d.ts +192 -0
  54. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/types.js +9 -0
  55. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/utils.d.ts +22 -0
  56. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/utils.js +128 -0
  57. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/version.d.ts +1 -0
  58. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/version.js +2 -0
  59. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/workletUrl.d.ts +6 -0
  60. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/workletUrl.js +17 -0
  61. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/AudioControl.d.ts +28 -0
  62. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/AudioControl.js +99 -0
  63. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/ContextMenu.d.ts +17 -0
  64. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/ContextMenu.js +73 -0
  65. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/ControlSection.d.ts +26 -0
  66. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/ControlSection.js +74 -0
  67. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/DetuneControl.d.ts +10 -0
  68. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/DetuneControl.js +44 -0
  69. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/DisplayPanel.d.ts +14 -0
  70. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/DisplayPanel.js +6 -0
  71. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/FilterControl.d.ts +12 -0
  72. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/FilterControl.js +48 -0
  73. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/GainControl.d.ts +10 -0
  74. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/GainControl.js +44 -0
  75. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/PanControl.d.ts +10 -0
  76. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/PanControl.js +50 -0
  77. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/PlaybackRateControl.d.ts +10 -0
  78. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/PlaybackRateControl.js +44 -0
  79. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/PlayheadSlider.d.ts +13 -0
  80. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/PlayheadSlider.js +20 -0
  81. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/SnappableSlider.d.ts +18 -0
  82. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/SnappableSlider.js +174 -0
  83. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/TransportButtons.d.ts +14 -0
  84. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/TransportButtons.js +9 -0
  85. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/controls/controlDefs.d.ts +31 -0
  86. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/controls/controlDefs.js +211 -0
  87. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/controls/formatValueText.d.ts +2 -0
  88. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/controls/formatValueText.js +80 -0
  89. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/controls/linkedControlPairs.d.ts +20 -0
  90. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/controls/linkedControlPairs.js +51 -0
  91. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/data/cache.d.ts +1 -0
  92. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/data/cache.js +17 -0
  93. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/data/fileStore.d.ts +6 -0
  94. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/data/fileStore.js +39 -0
  95. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/hooks/useClipNode.d.ts +31 -0
  96. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/hooks/useClipNode.js +338 -0
  97. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/lib-react.d.ts +15 -0
  98. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/lib-react.js +17 -0
  99. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/lib.d.ts +16 -0
  100. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/lib.js +16 -0
  101. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/processor.js +4 -0
  102. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/processor.js.map +12 -0
  103. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/store/clipStore.d.ts +63 -0
  104. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/store/clipStore.js +71 -0
  105. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/styles.css +739 -0
  106. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/README.md +10 -0
  107. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/cdn-vanilla/README.md +13 -0
  108. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/cdn-vanilla/index.html +61 -0
  109. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/esm-bundler/README.md +8 -0
  110. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/esm-bundler/index.html +12 -0
  111. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/esm-bundler/package.json +15 -0
  112. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/esm-bundler/src/main.ts +43 -0
  113. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/react/README.md +10 -0
  114. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/react/index.html +12 -0
  115. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/react/package.json +21 -0
  116. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/react/src/App.tsx +20 -0
  117. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/react/src/main.tsx +9 -0
  118. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/react/vite.config.ts +6 -0
  119. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/self-hosted/README.md +11 -0
  120. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/self-hosted/index.html +12 -0
  121. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/self-hosted/package.json +16 -0
  122. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/self-hosted/public/.gitkeep +1 -0
  123. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/self-hosted/src/main.ts +46 -0
  124. package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/package.json +88 -0
  125. package/examples/esm-bundler/node_modules/@rollup/rollup-darwin-arm64/README.md +3 -0
  126. package/examples/esm-bundler/node_modules/@rollup/rollup-darwin-arm64/package.json +22 -0
  127. package/examples/esm-bundler/node_modules/@rollup/rollup-darwin-arm64/rollup.darwin-arm64.node +0 -0
  128. package/examples/esm-bundler/node_modules/@types/estree/LICENSE +21 -0
  129. package/examples/esm-bundler/node_modules/@types/estree/README.md +15 -0
  130. package/examples/esm-bundler/node_modules/@types/estree/flow.d.ts +167 -0
  131. package/examples/esm-bundler/node_modules/@types/estree/index.d.ts +694 -0
  132. package/examples/esm-bundler/node_modules/@types/estree/package.json +27 -0
  133. package/examples/esm-bundler/node_modules/esbuild/LICENSE.md +21 -0
  134. package/examples/esm-bundler/node_modules/esbuild/README.md +3 -0
  135. package/examples/esm-bundler/node_modules/esbuild/bin/esbuild +0 -0
  136. package/examples/esm-bundler/node_modules/esbuild/install.js +289 -0
  137. package/examples/esm-bundler/node_modules/esbuild/lib/main.d.ts +716 -0
  138. package/examples/esm-bundler/node_modules/esbuild/lib/main.js +2242 -0
  139. package/examples/esm-bundler/node_modules/esbuild/package.json +49 -0
  140. package/examples/esm-bundler/node_modules/fdir/LICENSE +7 -0
  141. package/examples/esm-bundler/node_modules/fdir/README.md +91 -0
  142. package/examples/esm-bundler/node_modules/fdir/dist/index.cjs +588 -0
  143. package/examples/esm-bundler/node_modules/fdir/dist/index.d.cts +155 -0
  144. package/examples/esm-bundler/node_modules/fdir/dist/index.d.mts +155 -0
  145. package/examples/esm-bundler/node_modules/fdir/dist/index.mjs +570 -0
  146. package/examples/esm-bundler/node_modules/fdir/package.json +103 -0
  147. package/examples/esm-bundler/node_modules/nanoid/LICENSE +20 -0
  148. package/examples/esm-bundler/node_modules/nanoid/README.md +39 -0
  149. package/examples/esm-bundler/node_modules/nanoid/async/index.browser.cjs +69 -0
  150. package/examples/esm-bundler/node_modules/nanoid/async/index.browser.js +34 -0
  151. package/examples/esm-bundler/node_modules/nanoid/async/index.cjs +71 -0
  152. package/examples/esm-bundler/node_modules/nanoid/async/index.d.ts +56 -0
  153. package/examples/esm-bundler/node_modules/nanoid/async/index.js +35 -0
  154. package/examples/esm-bundler/node_modules/nanoid/async/index.native.js +26 -0
  155. package/examples/esm-bundler/node_modules/nanoid/async/package.json +12 -0
  156. package/examples/esm-bundler/node_modules/nanoid/bin/nanoid.cjs +55 -0
  157. package/examples/esm-bundler/node_modules/nanoid/index.browser.cjs +72 -0
  158. package/examples/esm-bundler/node_modules/nanoid/index.browser.js +34 -0
  159. package/examples/esm-bundler/node_modules/nanoid/index.cjs +85 -0
  160. package/examples/esm-bundler/node_modules/nanoid/index.d.cts +91 -0
  161. package/examples/esm-bundler/node_modules/nanoid/index.d.ts +91 -0
  162. package/examples/esm-bundler/node_modules/nanoid/index.js +45 -0
  163. package/examples/esm-bundler/node_modules/nanoid/nanoid.js +1 -0
  164. package/examples/esm-bundler/node_modules/nanoid/non-secure/index.cjs +34 -0
  165. package/examples/esm-bundler/node_modules/nanoid/non-secure/index.d.ts +33 -0
  166. package/examples/esm-bundler/node_modules/nanoid/non-secure/index.js +21 -0
  167. package/examples/esm-bundler/node_modules/nanoid/non-secure/package.json +6 -0
  168. package/examples/esm-bundler/node_modules/nanoid/package.json +89 -0
  169. package/examples/esm-bundler/node_modules/nanoid/url-alphabet/index.cjs +7 -0
  170. package/examples/esm-bundler/node_modules/nanoid/url-alphabet/index.js +3 -0
  171. package/examples/esm-bundler/node_modules/nanoid/url-alphabet/package.json +6 -0
  172. package/examples/esm-bundler/node_modules/picocolors/LICENSE +15 -0
  173. package/examples/esm-bundler/node_modules/picocolors/README.md +21 -0
  174. package/examples/esm-bundler/node_modules/picocolors/package.json +25 -0
  175. package/examples/esm-bundler/node_modules/picocolors/picocolors.browser.js +4 -0
  176. package/examples/esm-bundler/node_modules/picocolors/picocolors.d.ts +5 -0
  177. package/examples/esm-bundler/node_modules/picocolors/picocolors.js +75 -0
  178. package/examples/esm-bundler/node_modules/picocolors/types.d.ts +51 -0
  179. package/examples/esm-bundler/node_modules/picomatch/LICENSE +21 -0
  180. package/examples/esm-bundler/node_modules/picomatch/README.md +749 -0
  181. package/examples/esm-bundler/node_modules/picomatch/index.js +17 -0
  182. package/examples/esm-bundler/node_modules/picomatch/lib/constants.js +184 -0
  183. package/examples/esm-bundler/node_modules/picomatch/lib/parse.js +1386 -0
  184. package/examples/esm-bundler/node_modules/picomatch/lib/picomatch.js +349 -0
  185. package/examples/esm-bundler/node_modules/picomatch/lib/scan.js +391 -0
  186. package/examples/esm-bundler/node_modules/picomatch/lib/utils.js +72 -0
  187. package/examples/esm-bundler/node_modules/picomatch/package.json +82 -0
  188. package/examples/esm-bundler/node_modules/picomatch/posix.js +3 -0
  189. package/examples/esm-bundler/node_modules/postcss/LICENSE +20 -0
  190. package/examples/esm-bundler/node_modules/postcss/README.md +28 -0
  191. package/examples/esm-bundler/node_modules/postcss/lib/at-rule.d.ts +139 -0
  192. package/examples/esm-bundler/node_modules/postcss/lib/at-rule.js +25 -0
  193. package/examples/esm-bundler/node_modules/postcss/lib/comment.d.ts +67 -0
  194. package/examples/esm-bundler/node_modules/postcss/lib/comment.js +13 -0
  195. package/examples/esm-bundler/node_modules/postcss/lib/container.d.ts +478 -0
  196. package/examples/esm-bundler/node_modules/postcss/lib/container.js +447 -0
  197. package/examples/esm-bundler/node_modules/postcss/lib/css-syntax-error.d.ts +247 -0
  198. package/examples/esm-bundler/node_modules/postcss/lib/css-syntax-error.js +133 -0
  199. package/examples/esm-bundler/node_modules/postcss/lib/declaration.d.ts +150 -0
  200. package/examples/esm-bundler/node_modules/postcss/lib/declaration.js +24 -0
  201. package/examples/esm-bundler/node_modules/postcss/lib/document.d.ts +68 -0
  202. package/examples/esm-bundler/node_modules/postcss/lib/document.js +33 -0
  203. package/examples/esm-bundler/node_modules/postcss/lib/fromJSON.d.ts +9 -0
  204. package/examples/esm-bundler/node_modules/postcss/lib/fromJSON.js +54 -0
  205. package/examples/esm-bundler/node_modules/postcss/lib/input.d.ts +226 -0
  206. package/examples/esm-bundler/node_modules/postcss/lib/input.js +273 -0
  207. package/examples/esm-bundler/node_modules/postcss/lib/lazy-result.d.ts +189 -0
  208. package/examples/esm-bundler/node_modules/postcss/lib/lazy-result.js +550 -0
  209. package/examples/esm-bundler/node_modules/postcss/lib/list.d.ts +60 -0
  210. package/examples/esm-bundler/node_modules/postcss/lib/list.js +58 -0
  211. package/examples/esm-bundler/node_modules/postcss/lib/map-generator.js +376 -0
  212. package/examples/esm-bundler/node_modules/postcss/lib/no-work-result.d.ts +45 -0
  213. package/examples/esm-bundler/node_modules/postcss/lib/no-work-result.js +137 -0
  214. package/examples/esm-bundler/node_modules/postcss/lib/node.d.ts +555 -0
  215. package/examples/esm-bundler/node_modules/postcss/lib/node.js +449 -0
  216. package/examples/esm-bundler/node_modules/postcss/lib/parse.d.ts +9 -0
  217. package/examples/esm-bundler/node_modules/postcss/lib/parse.js +42 -0
  218. package/examples/esm-bundler/node_modules/postcss/lib/parser.js +611 -0
  219. package/examples/esm-bundler/node_modules/postcss/lib/postcss.d.mts +66 -0
  220. package/examples/esm-bundler/node_modules/postcss/lib/postcss.d.ts +456 -0
  221. package/examples/esm-bundler/node_modules/postcss/lib/postcss.js +101 -0
  222. package/examples/esm-bundler/node_modules/postcss/lib/postcss.mjs +30 -0
  223. package/examples/esm-bundler/node_modules/postcss/lib/previous-map.d.ts +80 -0
  224. package/examples/esm-bundler/node_modules/postcss/lib/previous-map.js +145 -0
  225. package/examples/esm-bundler/node_modules/postcss/lib/processor.d.ts +114 -0
  226. package/examples/esm-bundler/node_modules/postcss/lib/processor.js +67 -0
  227. package/examples/esm-bundler/node_modules/postcss/lib/result.d.ts +204 -0
  228. package/examples/esm-bundler/node_modules/postcss/lib/result.js +42 -0
  229. package/examples/esm-bundler/node_modules/postcss/lib/root.d.ts +86 -0
  230. package/examples/esm-bundler/node_modules/postcss/lib/root.js +61 -0
  231. package/examples/esm-bundler/node_modules/postcss/lib/rule.d.ts +126 -0
  232. package/examples/esm-bundler/node_modules/postcss/lib/rule.js +27 -0
  233. package/examples/esm-bundler/node_modules/postcss/lib/stringifier.d.ts +45 -0
  234. package/examples/esm-bundler/node_modules/postcss/lib/stringifier.js +353 -0
  235. package/examples/esm-bundler/node_modules/postcss/lib/stringify.d.ts +9 -0
  236. package/examples/esm-bundler/node_modules/postcss/lib/stringify.js +11 -0
  237. package/examples/esm-bundler/node_modules/postcss/lib/symbols.js +5 -0
  238. package/examples/esm-bundler/node_modules/postcss/lib/terminal-highlight.js +70 -0
  239. package/examples/esm-bundler/node_modules/postcss/lib/tokenize.js +266 -0
  240. package/examples/esm-bundler/node_modules/postcss/lib/warn-once.js +13 -0
  241. package/examples/esm-bundler/node_modules/postcss/lib/warning.d.ts +146 -0
  242. package/examples/esm-bundler/node_modules/postcss/lib/warning.js +37 -0
  243. package/examples/esm-bundler/node_modules/postcss/package.json +88 -0
  244. package/examples/esm-bundler/node_modules/rollup/LICENSE.md +679 -0
  245. package/examples/esm-bundler/node_modules/rollup/README.md +134 -0
  246. package/examples/esm-bundler/node_modules/rollup/dist/bin/rollup +1912 -0
  247. package/examples/esm-bundler/node_modules/rollup/dist/es/getLogFilter.js +64 -0
  248. package/examples/esm-bundler/node_modules/rollup/dist/es/package.json +1 -0
  249. package/examples/esm-bundler/node_modules/rollup/dist/es/parseAst.js +12 -0
  250. package/examples/esm-bundler/node_modules/rollup/dist/es/rollup.js +17 -0
  251. package/examples/esm-bundler/node_modules/rollup/dist/es/shared/node-entry.js +24463 -0
  252. package/examples/esm-bundler/node_modules/rollup/dist/es/shared/parseAst.js +2124 -0
  253. package/examples/esm-bundler/node_modules/rollup/dist/es/shared/watch.js +9909 -0
  254. package/examples/esm-bundler/node_modules/rollup/dist/getLogFilter.d.ts +5 -0
  255. package/examples/esm-bundler/node_modules/rollup/dist/getLogFilter.js +69 -0
  256. package/examples/esm-bundler/node_modules/rollup/dist/loadConfigFile.d.ts +20 -0
  257. package/examples/esm-bundler/node_modules/rollup/dist/loadConfigFile.js +29 -0
  258. package/examples/esm-bundler/node_modules/rollup/dist/native.js +161 -0
  259. package/examples/esm-bundler/node_modules/rollup/dist/parseAst.d.ts +4 -0
  260. package/examples/esm-bundler/node_modules/rollup/dist/parseAst.js +22 -0
  261. package/examples/esm-bundler/node_modules/rollup/dist/rollup.d.ts +1225 -0
  262. package/examples/esm-bundler/node_modules/rollup/dist/rollup.js +127 -0
  263. package/examples/esm-bundler/node_modules/rollup/dist/shared/fsevents-importer.js +37 -0
  264. package/examples/esm-bundler/node_modules/rollup/dist/shared/index.js +9615 -0
  265. package/examples/esm-bundler/node_modules/rollup/dist/shared/loadConfigFile.js +572 -0
  266. package/examples/esm-bundler/node_modules/rollup/dist/shared/parseAst.js +2361 -0
  267. package/examples/esm-bundler/node_modules/rollup/dist/shared/rollup.js +24385 -0
  268. package/examples/esm-bundler/node_modules/rollup/dist/shared/watch-cli.js +542 -0
  269. package/examples/esm-bundler/node_modules/rollup/dist/shared/watch.js +324 -0
  270. package/examples/esm-bundler/node_modules/rollup/package.json +289 -0
  271. package/examples/esm-bundler/node_modules/source-map-js/LICENSE +28 -0
  272. package/examples/esm-bundler/node_modules/source-map-js/README.md +765 -0
  273. package/examples/esm-bundler/node_modules/source-map-js/lib/array-set.js +121 -0
  274. package/examples/esm-bundler/node_modules/source-map-js/lib/base64-vlq.js +140 -0
  275. package/examples/esm-bundler/node_modules/source-map-js/lib/base64.js +67 -0
  276. package/examples/esm-bundler/node_modules/source-map-js/lib/binary-search.js +111 -0
  277. package/examples/esm-bundler/node_modules/source-map-js/lib/mapping-list.js +79 -0
  278. package/examples/esm-bundler/node_modules/source-map-js/lib/quick-sort.js +132 -0
  279. package/examples/esm-bundler/node_modules/source-map-js/lib/source-map-consumer.d.ts +1 -0
  280. package/examples/esm-bundler/node_modules/source-map-js/lib/source-map-consumer.js +1188 -0
  281. package/examples/esm-bundler/node_modules/source-map-js/lib/source-map-generator.d.ts +1 -0
  282. package/examples/esm-bundler/node_modules/source-map-js/lib/source-map-generator.js +444 -0
  283. package/examples/esm-bundler/node_modules/source-map-js/lib/source-node.d.ts +1 -0
  284. package/examples/esm-bundler/node_modules/source-map-js/lib/source-node.js +413 -0
  285. package/examples/esm-bundler/node_modules/source-map-js/lib/util.js +594 -0
  286. package/examples/esm-bundler/node_modules/source-map-js/package.json +71 -0
  287. package/examples/esm-bundler/node_modules/source-map-js/source-map.d.ts +104 -0
  288. package/examples/esm-bundler/node_modules/source-map-js/source-map.js +8 -0
  289. package/examples/esm-bundler/node_modules/tinyglobby/LICENSE +21 -0
  290. package/examples/esm-bundler/node_modules/tinyglobby/README.md +25 -0
  291. package/examples/esm-bundler/node_modules/tinyglobby/dist/index.cjs +334 -0
  292. package/examples/esm-bundler/node_modules/tinyglobby/dist/index.d.cts +148 -0
  293. package/examples/esm-bundler/node_modules/tinyglobby/dist/index.d.mts +148 -0
  294. package/examples/esm-bundler/node_modules/tinyglobby/dist/index.mjs +306 -0
  295. package/examples/esm-bundler/node_modules/tinyglobby/package.json +73 -0
  296. package/examples/esm-bundler/node_modules/vite/LICENSE.md +2406 -0
  297. package/examples/esm-bundler/node_modules/vite/README.md +20 -0
  298. package/examples/esm-bundler/node_modules/vite/bin/openChrome.applescript +95 -0
  299. package/examples/esm-bundler/node_modules/vite/bin/vite.js +79 -0
  300. package/examples/esm-bundler/node_modules/vite/client.d.ts +279 -0
  301. package/examples/esm-bundler/node_modules/vite/dist/client/client.mjs +1134 -0
  302. package/examples/esm-bundler/node_modules/vite/dist/client/env.mjs +24 -0
  303. package/examples/esm-bundler/node_modules/vite/dist/node/chunks/dep-3RmXg9uo.js +553 -0
  304. package/examples/esm-bundler/node_modules/vite/dist/node/chunks/dep-4-IQbZQm.js +822 -0
  305. package/examples/esm-bundler/node_modules/vite/dist/node/chunks/dep-CvfTChi5.js +8218 -0
  306. package/examples/esm-bundler/node_modules/vite/dist/node/chunks/dep-Dq2t6Dq0.js +49565 -0
  307. package/examples/esm-bundler/node_modules/vite/dist/node/chunks/dep-lpEPC2f9.js +7113 -0
  308. package/examples/esm-bundler/node_modules/vite/dist/node/cli.js +949 -0
  309. package/examples/esm-bundler/node_modules/vite/dist/node/constants.js +149 -0
  310. package/examples/esm-bundler/node_modules/vite/dist/node/index.d.ts +4227 -0
  311. package/examples/esm-bundler/node_modules/vite/dist/node/index.js +194 -0
  312. package/examples/esm-bundler/node_modules/vite/dist/node/module-runner.d.ts +290 -0
  313. package/examples/esm-bundler/node_modules/vite/dist/node/module-runner.js +1311 -0
  314. package/examples/esm-bundler/node_modules/vite/dist/node/moduleRunnerTransport.d-DJ_mE5sf.d.ts +87 -0
  315. package/examples/esm-bundler/node_modules/vite/dist/node-cjs/publicUtils.cjs +3987 -0
  316. package/examples/esm-bundler/node_modules/vite/index.cjs +96 -0
  317. package/examples/esm-bundler/node_modules/vite/index.d.cts +6 -0
  318. package/examples/esm-bundler/node_modules/vite/misc/false.js +1 -0
  319. package/examples/esm-bundler/node_modules/vite/misc/true.js +1 -0
  320. package/examples/esm-bundler/node_modules/vite/package.json +204 -0
  321. package/examples/esm-bundler/node_modules/vite/types/customEvent.d.ts +45 -0
  322. package/examples/esm-bundler/node_modules/vite/types/hmrPayload.d.ts +74 -0
  323. package/examples/esm-bundler/node_modules/vite/types/hot.d.ts +39 -0
  324. package/examples/esm-bundler/node_modules/vite/types/import-meta.d.ts +5 -0
  325. package/examples/esm-bundler/node_modules/vite/types/importGlob.d.ts +75 -0
  326. package/examples/esm-bundler/node_modules/vite/types/importMeta.d.ts +31 -0
  327. package/examples/esm-bundler/node_modules/vite/types/internal/cssPreprocessorOptions.d.ts +63 -0
  328. package/examples/esm-bundler/node_modules/vite/types/internal/lightningcssOptions.d.ts +18 -0
  329. package/examples/esm-bundler/node_modules/vite/types/metadata.d.ts +35 -0
  330. package/examples/esm-bundler/node_modules/vite/types/package.json +4 -0
  331. package/examples/esm-bundler/package-lock.json +1127 -0
  332. package/examples/esm-bundler/package.json +15 -0
  333. package/examples/esm-bundler/src/main.ts +43 -0
  334. package/examples/react/README.md +10 -0
  335. package/examples/react/index.html +12 -0
  336. package/examples/react/package.json +19 -0
  337. package/examples/react/src/App.tsx +20 -0
  338. package/examples/react/src/main.tsx +9 -0
  339. package/examples/self-hosted/README.md +11 -0
  340. package/examples/self-hosted/index.html +12 -0
  341. package/examples/self-hosted/package.json +16 -0
  342. package/examples/self-hosted/public/.gitkeep +1 -0
  343. package/examples/self-hosted/src/main.ts +46 -0
  344. package/package.json +4 -2
  345. package/dist/lib-react.js.map +0 -9
  346. package/dist/lib.js.map +0 -9
@@ -0,0 +1,50 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { memo, useCallback, useId, useRef, useState } from "react";
3
+ import { presets } from "../audio/utils";
4
+ import { SnappableSlider } from "./SnappableSlider";
5
+ function formatPan(value) {
6
+ if (Math.abs(value) < 0.005)
7
+ return "C";
8
+ const pct = Math.round(Math.abs(value) * 100);
9
+ return value < 0 ? `L${pct}` : `R${pct}`;
10
+ }
11
+ function PanControlInner({ value, defaultValue, enabled, onChange, onToggle, }) {
12
+ const preset = presets.pan;
13
+ const min = preset.min ?? -1;
14
+ const max = preset.max ?? 1;
15
+ const labelId = useId();
16
+ const [isEditing, setIsEditing] = useState(false);
17
+ const [editText, setEditText] = useState("");
18
+ const inputRef = useRef(null);
19
+ const displayValue = formatPan(value);
20
+ const handleChange = useCallback((v) => {
21
+ if (!enabled)
22
+ return;
23
+ onChange(v);
24
+ }, [enabled, onChange]);
25
+ const startEditing = useCallback(() => {
26
+ setEditText(String(value));
27
+ setIsEditing(true);
28
+ queueMicrotask(() => inputRef.current?.select());
29
+ }, [value]);
30
+ const commitEdit = useCallback(() => {
31
+ setIsEditing(false);
32
+ const parsed = Number.parseFloat(editText);
33
+ if (Number.isFinite(parsed)) {
34
+ onChange(Math.min(Math.max(parsed, min), max));
35
+ }
36
+ }, [editText, min, max, onChange]);
37
+ const handleEditKeyDown = useCallback((e) => {
38
+ if (e.key === "Enter") {
39
+ e.preventDefault();
40
+ commitEdit();
41
+ }
42
+ else if (e.key === "Escape") {
43
+ e.preventDefault();
44
+ setIsEditing(false);
45
+ }
46
+ }, [commitEdit]);
47
+ const disabled = !enabled;
48
+ return (_jsxs("div", { className: `audio-control${disabled ? " audio-control--disabled" : ""}`, title: "-1 full left, 1 full right.", children: [_jsx("input", { type: "checkbox", className: "control-toggle", checked: enabled, onChange: (e) => onToggle(e.target.checked) }), _jsx("span", { className: "control-label", id: labelId, children: "Pan" }), _jsx(SnappableSlider, { min: min, max: max, value: value, skew: preset.skew ?? 1, defaultValue: defaultValue, ticks: preset.ticks ?? [], disabled: disabled, labelId: labelId, valueText: displayValue, onChange: handleChange }), isEditing ? (_jsx("input", { ref: inputRef, type: "text", className: "control-output control-output--editing", value: editText, onChange: (e) => setEditText(e.target.value), onBlur: commitEdit, onKeyDown: handleEditKeyDown })) : (_jsx("button", { type: "button", className: "control-output", onClick: startEditing, children: displayValue }))] }));
49
+ }
50
+ export const PanControl = memo(PanControlInner);
@@ -0,0 +1,44 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { memo, useCallback, useId, useRef, useState } from "react";
3
+ import { presets } from "../audio/utils";
4
+ import { SnappableSlider } from "./SnappableSlider";
5
+ function PlaybackRateControlInner({ value, defaultValue, enabled, onChange, onToggle, }) {
6
+ const preset = presets.playbackRate;
7
+ const min = preset.min ?? -4;
8
+ const max = preset.max ?? 4;
9
+ const labelId = useId();
10
+ const [isEditing, setIsEditing] = useState(false);
11
+ const [editText, setEditText] = useState("");
12
+ const inputRef = useRef(null);
13
+ const displayValue = `${value.toFixed(2)}x`;
14
+ const handleChange = useCallback((v) => {
15
+ if (!enabled)
16
+ return;
17
+ onChange(v);
18
+ }, [enabled, onChange]);
19
+ const startEditing = useCallback(() => {
20
+ setEditText(String(value));
21
+ setIsEditing(true);
22
+ queueMicrotask(() => inputRef.current?.select());
23
+ }, [value]);
24
+ const commitEdit = useCallback(() => {
25
+ setIsEditing(false);
26
+ const parsed = Number.parseFloat(editText);
27
+ if (Number.isFinite(parsed)) {
28
+ onChange(Math.min(Math.max(parsed, min), max));
29
+ }
30
+ }, [editText, min, max, onChange]);
31
+ const handleEditKeyDown = useCallback((e) => {
32
+ if (e.key === "Enter") {
33
+ e.preventDefault();
34
+ commitEdit();
35
+ }
36
+ else if (e.key === "Escape") {
37
+ e.preventDefault();
38
+ setIsEditing(false);
39
+ }
40
+ }, [commitEdit]);
41
+ const disabled = !enabled;
42
+ return (_jsxs("div", { className: `audio-control${disabled ? " audio-control--disabled" : ""}`, title: "Playback speed. Negative for reverse.", children: [_jsx("input", { type: "checkbox", className: "control-toggle", checked: enabled, onChange: (e) => onToggle(e.target.checked) }), _jsx("span", { className: "control-label", id: labelId, children: "Rate" }), _jsx(SnappableSlider, { min: min, max: max, value: value, skew: preset.skew ?? 1, defaultValue: defaultValue, enableSnap: true, snaps: preset.snaps ?? [], ticks: preset.ticks ?? [], disabled: disabled, labelId: labelId, valueText: displayValue, onChange: handleChange }), isEditing ? (_jsx("input", { ref: inputRef, type: "text", className: "control-output control-output--editing", value: editText, onChange: (e) => setEditText(e.target.value), onBlur: commitEdit, onKeyDown: handleEditKeyDown })) : (_jsx("button", { type: "button", className: "control-output", onClick: startEditing, children: displayValue }))] }));
43
+ }
44
+ export const PlaybackRateControl = memo(PlaybackRateControlInner);
@@ -0,0 +1,20 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { memo, useCallback, useId } from "react";
3
+ import { SAMPLE_RATE } from "../controls/controlDefs";
4
+ import { SnappableSlider } from "./SnappableSlider";
5
+ function formatTime(seconds) {
6
+ const m = Math.floor(seconds / 60);
7
+ const s = seconds % 60;
8
+ return `${m}:${s.toFixed(2).padStart(5, "0")}`;
9
+ }
10
+ function PlayheadSliderInner({ value, audioDuration, disabled = false, onChange, }) {
11
+ const labelId = useId();
12
+ const maxSamples = audioDuration != null ? audioDuration * SAMPLE_RATE : 0;
13
+ const currentSeconds = value / SAMPLE_RATE;
14
+ const durationSeconds = audioDuration ?? 0;
15
+ const handleChange = useCallback((v) => {
16
+ onChange(Math.floor(v));
17
+ }, [onChange]);
18
+ return (_jsxs("div", { className: "playhead-slider", children: [_jsx("span", { className: "playhead-label", id: labelId, children: "Playhead" }), _jsx(SnappableSlider, { min: 0, max: maxSamples, value: value, disabled: disabled || maxSamples === 0, labelId: labelId, valueText: formatTime(currentSeconds), onChange: handleChange }), _jsxs("span", { className: "playhead-time", children: [formatTime(currentSeconds), " / ", formatTime(durationSeconds)] })] }));
19
+ }
20
+ export const PlayheadSlider = memo(PlayheadSliderInner);
@@ -0,0 +1,174 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useCallback, useMemo, useRef, useState } from "react";
3
+ export function SnappableSlider({ min, max, value, skew = 1, step, defaultValue, enableSnap = false, snaps = [], ticks = [], logarithmic = false, disabled = false, labelId, valueText, formatTick, onChange, }) {
4
+ const containerRef = useRef(null);
5
+ const isDragging = useRef(false);
6
+ const isOptionKeyHeld = useRef(false);
7
+ const dragBoundsRef = useRef(null);
8
+ const [altHeld, setAltHeld] = useState(false);
9
+ const resolvedStep = step ?? (max - min) / 100;
10
+ const getRatioFromValue = useCallback((v) => {
11
+ if (logarithmic) {
12
+ if (min <= 0 || max <= 0)
13
+ return 0;
14
+ const clamped = Math.max(v, min);
15
+ return Math.log(clamped / min) / Math.log(max / min);
16
+ }
17
+ const range = max - min;
18
+ if (range === 0)
19
+ return 0;
20
+ const normalized = (v - min) / range;
21
+ return skew === 1 ? normalized : Math.max(normalized, 0) ** skew;
22
+ }, [min, max, skew, logarithmic]);
23
+ const getValueFromRatio = useCallback((ratio) => {
24
+ if (logarithmic) {
25
+ if (min <= 0 || max <= 0)
26
+ return min;
27
+ return min * (max / min) ** ratio;
28
+ }
29
+ const adjusted = skew === 1 ? ratio : ratio ** (1 / skew);
30
+ return adjusted * (max - min) + min;
31
+ }, [min, max, skew, logarithmic]);
32
+ const getSnapped = useCallback((v) => {
33
+ if (!enableSnap || snaps.length === 0 || isOptionKeyHeld.current)
34
+ return v;
35
+ return snaps.reduce((closest, snap) => Math.abs(snap - v) < Math.abs(closest - v) ? snap : closest);
36
+ }, [enableSnap, snaps]);
37
+ const clampAndEmit = useCallback((raw) => {
38
+ const clamped = Math.min(Math.max(raw, min), max);
39
+ const snapped = getSnapped(clamped);
40
+ onChange?.(snapped);
41
+ }, [min, max, getSnapped, onChange]);
42
+ const updateFromClientX = useCallback((clientX) => {
43
+ const el = containerRef.current;
44
+ if (!el)
45
+ return;
46
+ const bounds = dragBoundsRef.current ?? el.getBoundingClientRect();
47
+ const { left, width } = bounds;
48
+ if (width <= 0)
49
+ return;
50
+ const ratio = Math.min(Math.max((clientX - left) / width, 0), 1);
51
+ const raw = getValueFromRatio(ratio);
52
+ const snapped = getSnapped(raw);
53
+ onChange?.(snapped);
54
+ }, [getValueFromRatio, getSnapped, onChange]);
55
+ const startDrag = useCallback((clientX, altKey) => {
56
+ if (disabled)
57
+ return;
58
+ const el = containerRef.current;
59
+ if (!el)
60
+ return;
61
+ dragBoundsRef.current = el.getBoundingClientRect();
62
+ isDragging.current = true;
63
+ isOptionKeyHeld.current = altKey;
64
+ setAltHeld(altKey);
65
+ updateFromClientX(clientX);
66
+ const handleMove = (e) => {
67
+ if (isOptionKeyHeld.current !== e.altKey) {
68
+ isOptionKeyHeld.current = e.altKey;
69
+ setAltHeld(e.altKey);
70
+ }
71
+ updateFromClientX(e.clientX);
72
+ };
73
+ const handleTouchMove = (e) => updateFromClientX(e.touches[0].clientX);
74
+ const handleUp = () => {
75
+ isDragging.current = false;
76
+ isOptionKeyHeld.current = false;
77
+ dragBoundsRef.current = null;
78
+ setAltHeld(false);
79
+ document.removeEventListener("mousemove", handleMove);
80
+ document.removeEventListener("mouseup", handleUp);
81
+ document.removeEventListener("touchmove", handleTouchMove);
82
+ document.removeEventListener("touchend", handleUp);
83
+ };
84
+ document.addEventListener("mousemove", handleMove);
85
+ document.addEventListener("mouseup", handleUp);
86
+ document.addEventListener("touchmove", handleTouchMove);
87
+ document.addEventListener("touchend", handleUp);
88
+ }, [updateFromClientX, disabled]);
89
+ const handleKeyDown = useCallback((e) => {
90
+ if (e.key === "Alt") {
91
+ isOptionKeyHeld.current = true;
92
+ setAltHeld(true);
93
+ return;
94
+ }
95
+ if (disabled)
96
+ return;
97
+ let newValue = value;
98
+ const s = resolvedStep;
99
+ const bigStep = s * 10;
100
+ switch (e.key) {
101
+ case "ArrowRight":
102
+ case "ArrowUp":
103
+ newValue = value + s;
104
+ break;
105
+ case "ArrowLeft":
106
+ case "ArrowDown":
107
+ newValue = value - s;
108
+ break;
109
+ case "PageUp":
110
+ newValue = value + bigStep;
111
+ break;
112
+ case "PageDown":
113
+ newValue = value - bigStep;
114
+ break;
115
+ case "Home":
116
+ newValue = min;
117
+ break;
118
+ case "End":
119
+ newValue = max;
120
+ break;
121
+ default:
122
+ return;
123
+ }
124
+ e.preventDefault();
125
+ clampAndEmit(newValue);
126
+ }, [value, resolvedStep, min, max, clampAndEmit, disabled]);
127
+ const handleKeyUp = useCallback((e) => {
128
+ if (e.key === "Alt") {
129
+ isOptionKeyHeld.current = false;
130
+ setAltHeld(false);
131
+ }
132
+ }, []);
133
+ const handleDoubleClick = useCallback(() => {
134
+ if (disabled)
135
+ return;
136
+ if (defaultValue !== undefined) {
137
+ onChange?.(defaultValue);
138
+ }
139
+ }, [defaultValue, onChange, disabled]);
140
+ const ratio = getRatioFromValue(value);
141
+ const pct = `${ratio * 100}%`;
142
+ const snapElements = useMemo(() => {
143
+ let prevRatio = -1;
144
+ return snaps.map((snap, i) => {
145
+ const r = getRatioFromValue(snap);
146
+ const show = i === 0 || r - prevRatio >= 0.05;
147
+ if (show)
148
+ prevRatio = r;
149
+ return (_jsxs("span", { children: [_jsx("span", { className: "slider-snap", style: { left: `${r * 100}%` } }), _jsx("span", { className: "slider-xval", style: { left: `${r * 100}%`, display: show ? "block" : "none" }, children: formatTick ? formatTick(snap) : snap })] }, snap));
150
+ });
151
+ }, [snaps, getRatioFromValue, formatTick]);
152
+ const tickElements = useMemo(() => {
153
+ let prevRatio = -1;
154
+ return ticks.map((tick) => {
155
+ const r = getRatioFromValue(tick);
156
+ const show = prevRatio < 0 || r - prevRatio >= 0.05;
157
+ if (show)
158
+ prevRatio = r;
159
+ return (_jsxs("span", { children: [_jsx("span", { className: "slider-tick", style: { left: `${r * 100}%` } }), _jsx("span", { className: "slider-xval", style: { left: `${r * 100}%`, display: show ? "block" : "none" }, children: formatTick ? formatTick(tick) : tick })] }, tick));
160
+ });
161
+ }, [ticks, getRatioFromValue, formatTick]);
162
+ const sliderClass = [
163
+ "snappable-slider",
164
+ disabled ? "snappable-slider--disabled" : "",
165
+ altHeld ? "snappable-slider--fine" : "",
166
+ ]
167
+ .filter(Boolean)
168
+ .join(" ");
169
+ return (_jsxs("div", { role: "slider", "aria-valuemin": min, "aria-valuemax": max, "aria-valuenow": value, "aria-valuetext": valueText, "aria-labelledby": labelId, "aria-disabled": disabled || undefined, tabIndex: disabled ? -1 : 0, ref: containerRef, className: sliderClass, onMouseDown: (e) => {
170
+ if (e.button !== 0)
171
+ return;
172
+ startDrag(e.clientX, e.altKey);
173
+ }, onTouchStart: (e) => startDrag(e.touches[0].clientX, false), onKeyDown: handleKeyDown, onKeyUp: handleKeyUp, onDoubleClick: handleDoubleClick, children: [_jsx("span", { className: "slider-track" }), _jsx("span", { className: "slider-fill", style: { width: pct } }), _jsx("span", { className: "slider-thumb", style: { left: pct } }), snapElements, tickElements] }));
174
+ }
@@ -0,0 +1,9 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { memo } from "react";
3
+ function TransportButtonsInner({ nodeState, onStart, onStop, onPause, onResume, onDispose, onLog, onLoadSound, }) {
4
+ const cantStop = nodeState === "initial" ||
5
+ nodeState === "disposed" ||
6
+ nodeState === "ended";
7
+ return (_jsxs("section", { id: "buttons", children: [_jsxs("div", { className: "btn-group-primary", children: [_jsx("button", { type: "button", onClick: onLoadSound, children: "Load Sound" }), _jsx("button", { type: "button", onClick: onStart, disabled: nodeState === "started", "aria-disabled": nodeState === "started", children: "Start" }), _jsx("button", { type: "button", onClick: onStop, disabled: cantStop, "aria-disabled": cantStop, children: "Stop" }), _jsx("button", { type: "button", onClick: onPause, disabled: nodeState !== "started" && nodeState !== "resumed", "aria-disabled": nodeState !== "started" && nodeState !== "resumed", children: "Pause" }), _jsx("button", { type: "button", onClick: onResume, disabled: nodeState !== "paused", "aria-disabled": nodeState !== "paused", children: "Resume" })] }), _jsxs("div", { className: "btn-group-secondary", children: [_jsx("button", { type: "button", className: "btn-secondary", onClick: onLog, children: "Log State" }), _jsx("button", { type: "button", className: "btn-secondary", onClick: onDispose, children: "Dispose" })] })] }));
8
+ }
9
+ export const TransportButtons = memo(TransportButtonsInner);
@@ -0,0 +1,211 @@
1
+ // ---------------------------------------------------------------------------
2
+ // Control definitions — shared configuration for all audio controls
3
+ // ---------------------------------------------------------------------------
4
+ export const DEFAULT_TEMPO = 120;
5
+ export const SAMPLE_RATE = 48000;
6
+ export const controlDefs = [
7
+ {
8
+ key: "offset",
9
+ label: "Offset",
10
+ min: 0,
11
+ max: 60,
12
+ defaultValue: 0,
13
+ snap: "bar",
14
+ hasSnap: true,
15
+ hasToggle: true,
16
+ hasMaxLock: true,
17
+ maxLockedByDefault: true,
18
+ title: "Start position in the buffer (seconds).",
19
+ },
20
+ {
21
+ key: "duration",
22
+ label: "Duration",
23
+ min: -1,
24
+ max: 60,
25
+ defaultValue: -1,
26
+ hasSnap: true,
27
+ hasToggle: true,
28
+ hasMaxLock: true,
29
+ maxLockedByDefault: true,
30
+ title: "How long to play before auto-stopping (seconds). -1 for full length.",
31
+ },
32
+ {
33
+ key: "startDelay",
34
+ label: "StartDelay",
35
+ min: 0,
36
+ max: 4,
37
+ defaultValue: 0,
38
+ snap: "beat",
39
+ hasSnap: true,
40
+ hasToggle: true,
41
+ title: "Delay before starting (seconds).",
42
+ },
43
+ {
44
+ key: "stopDelay",
45
+ label: "StopDelay",
46
+ min: 0,
47
+ max: 4,
48
+ defaultValue: 0,
49
+ snap: "beat",
50
+ hasSnap: true,
51
+ hasToggle: true,
52
+ title: "Delay before stopping (seconds).",
53
+ },
54
+ {
55
+ key: "fadeIn",
56
+ label: "FadeIn",
57
+ min: 0,
58
+ max: 60,
59
+ defaultValue: 0,
60
+ snap: "beat",
61
+ hasSnap: true,
62
+ hasToggle: true,
63
+ title: "Fade-in duration (seconds).",
64
+ },
65
+ {
66
+ key: "fadeOut",
67
+ label: "FadeOut",
68
+ min: 0,
69
+ max: 60,
70
+ defaultValue: 0,
71
+ snap: "beat",
72
+ hasSnap: true,
73
+ hasToggle: true,
74
+ title: "Fade-out duration (seconds).",
75
+ },
76
+ ];
77
+ export const loopControlDefs = [
78
+ {
79
+ key: "loopStart",
80
+ label: "Start",
81
+ min: 0,
82
+ max: 60,
83
+ defaultValue: 0,
84
+ snap: "bar",
85
+ hasSnap: true,
86
+ hasToggle: true,
87
+ hasMaxLock: true,
88
+ maxLockedByDefault: true,
89
+ },
90
+ {
91
+ key: "loopEnd",
92
+ label: "End",
93
+ min: 0,
94
+ max: 60,
95
+ defaultValue: 0,
96
+ snap: "bar",
97
+ hasSnap: true,
98
+ hasToggle: true,
99
+ hasMaxLock: true,
100
+ maxLockedByDefault: true,
101
+ },
102
+ {
103
+ key: "loopCrossfade",
104
+ label: "Crossfade",
105
+ min: 0,
106
+ max: 1,
107
+ defaultValue: 0,
108
+ snap: "beat",
109
+ hasSnap: true,
110
+ hasToggle: true,
111
+ },
112
+ ];
113
+ export const paramDefs = [
114
+ {
115
+ key: "playbackRate",
116
+ label: "PlaybackRate",
117
+ min: -2,
118
+ max: 2,
119
+ defaultValue: 1,
120
+ precision: 2,
121
+ preset: "playbackRate",
122
+ hasToggle: true,
123
+ title: "Playback speed. Negative for reverse.",
124
+ },
125
+ {
126
+ key: "detune",
127
+ label: "Detune",
128
+ min: -2400,
129
+ max: 2400,
130
+ defaultValue: 0,
131
+ precision: 4,
132
+ preset: "cents",
133
+ hasToggle: true,
134
+ title: "Pitch shift in cents.",
135
+ },
136
+ {
137
+ key: "gain",
138
+ label: "Gain",
139
+ min: -100,
140
+ max: 0,
141
+ defaultValue: 0,
142
+ precision: 3,
143
+ preset: "gain",
144
+ hasToggle: true,
145
+ title: "Amplitude in dB.",
146
+ },
147
+ {
148
+ key: "pan",
149
+ label: "Pan",
150
+ min: -1,
151
+ max: 1,
152
+ defaultValue: 0,
153
+ preset: "pan",
154
+ hasToggle: true,
155
+ title: "-1 full left, 1 full right.",
156
+ },
157
+ {
158
+ key: "lowpass",
159
+ label: "Lowpass",
160
+ min: 32,
161
+ max: 16384,
162
+ defaultValue: 16384,
163
+ preset: "hertz",
164
+ hasToggle: true,
165
+ title: "Lowpass cutoff frequency.",
166
+ },
167
+ {
168
+ key: "highpass",
169
+ label: "Highpass",
170
+ min: 32,
171
+ max: 16384,
172
+ defaultValue: 32,
173
+ preset: "hertz",
174
+ hasToggle: true,
175
+ title: "Highpass cutoff frequency.",
176
+ },
177
+ ];
178
+ /** Internal-only definition for playhead (not shown in UI). */
179
+ const playheadDef = {
180
+ key: "playhead",
181
+ label: "Playhead",
182
+ min: 0,
183
+ max: 480000,
184
+ defaultValue: 0,
185
+ precision: 1,
186
+ snap: "int",
187
+ title: "Current sample position of buffer playback.",
188
+ };
189
+ export const allDefs = [
190
+ playheadDef,
191
+ ...controlDefs,
192
+ ...loopControlDefs,
193
+ ...paramDefs,
194
+ ];
195
+ export function buildDefaults() {
196
+ const values = {};
197
+ const snaps = {};
198
+ const enabled = {};
199
+ const mins = {};
200
+ const maxs = {};
201
+ const maxLocked = {};
202
+ for (const d of allDefs) {
203
+ values[d.key] = d.defaultValue;
204
+ snaps[d.key] = d.snap ?? "none";
205
+ enabled[d.key] = true;
206
+ mins[d.key] = d.min;
207
+ maxs[d.key] = d.max;
208
+ maxLocked[d.key] = d.maxLockedByDefault ?? false;
209
+ }
210
+ return { values, snaps, enabled, mins, maxs, maxLocked };
211
+ }
@@ -0,0 +1,80 @@
1
+ export function formatValueText(value, key, snap, tempo) {
2
+ switch (key) {
3
+ case "gain":
4
+ return `${value.toFixed(1)} dB`;
5
+ case "lowpass":
6
+ case "highpass":
7
+ return `${Math.round(value)} Hz`;
8
+ case "detune":
9
+ return `${Math.round(value)} cents`;
10
+ case "pan":
11
+ if (value === 0)
12
+ return "center";
13
+ return value < 0
14
+ ? `${Math.abs(value).toFixed(2)} left`
15
+ : `${value.toFixed(2)} right`;
16
+ case "playbackRate":
17
+ return `${value.toFixed(2)}x`;
18
+ case "playhead":
19
+ return `sample ${Math.round(value)}`;
20
+ default:
21
+ break;
22
+ }
23
+ if (snap === "beat" || snap === "bar" || snap === "8th" || snap === "16th") {
24
+ const spb = 60 / tempo;
25
+ if (snap === "bar") {
26
+ const bars = value / (spb * 4);
27
+ return `${Math.round(bars)} bars`;
28
+ }
29
+ if (snap === "8th") {
30
+ const eighths = value / (spb / 2);
31
+ return `${Math.round(eighths)} 8ths`;
32
+ }
33
+ if (snap === "16th") {
34
+ const sixteenths = value / (spb / 4);
35
+ return `${Math.round(sixteenths)} 16ths`;
36
+ }
37
+ const beats = value / spb;
38
+ return `${Math.round(beats)} beats`;
39
+ }
40
+ if (snap === "integer") {
41
+ return `${Math.round(value)} s`;
42
+ }
43
+ return `${value.toPrecision(4)} s`;
44
+ }
45
+ export function formatTickLabel(value, key, snap, tempo) {
46
+ switch (key) {
47
+ case "gain":
48
+ return value.toFixed(1);
49
+ case "lowpass":
50
+ case "highpass":
51
+ return `${Math.round(value)}`;
52
+ case "detune":
53
+ return `${Math.round(value)}`;
54
+ case "pan":
55
+ if (value === 0)
56
+ return "C";
57
+ return value < 0
58
+ ? `${Math.abs(value).toFixed(2)}L`
59
+ : `${value.toFixed(2)}R`;
60
+ case "playbackRate":
61
+ return `${value.toFixed(2)}x`;
62
+ case "playhead":
63
+ return `${Math.round(value)}`;
64
+ default:
65
+ break;
66
+ }
67
+ if (snap === "beat" || snap === "bar" || snap === "8th" || snap === "16th") {
68
+ const spb = 60 / tempo;
69
+ if (snap === "bar")
70
+ return `${Math.round(value / (spb * 4))}`;
71
+ if (snap === "8th")
72
+ return `${Math.round(value / (spb / 2))}`;
73
+ if (snap === "16th")
74
+ return `${Math.round(value / (spb / 4))}`;
75
+ return `${Math.round(value / spb)}`;
76
+ }
77
+ if (snap === "integer")
78
+ return `${Math.round(value)}`;
79
+ return value.toPrecision(4);
80
+ }
@@ -0,0 +1,51 @@
1
+ export const transportLinkedControlPairs = [
2
+ {
3
+ key: "fadeOutStopDelay",
4
+ label: "Link StopDelay and FadeOut",
5
+ controls: ["stopDelay", "fadeOut"],
6
+ },
7
+ ];
8
+ export const loopLinkedControlPairs = [
9
+ {
10
+ key: "loopStartEnd",
11
+ label: "Link Start and End",
12
+ controls: ["loopStart", "loopEnd"],
13
+ },
14
+ ];
15
+ const allLinkedControlPairs = [
16
+ ...transportLinkedControlPairs,
17
+ ...loopLinkedControlPairs,
18
+ ];
19
+ export function buildLinkedControlPairDefaults() {
20
+ return {
21
+ fadeOutStopDelay: false,
22
+ loopStartEnd: false,
23
+ };
24
+ }
25
+ export function getLinkedControlPairForControl(controlKey) {
26
+ return allLinkedControlPairs.find((pair) => pair.controls[0] === controlKey || pair.controls[1] === controlKey);
27
+ }
28
+ export function getActiveLinkedControls(controlKey, linkedPairs) {
29
+ const pair = getLinkedControlPairForControl(controlKey);
30
+ if (pair && linkedPairs[pair.key]) {
31
+ return pair.controls;
32
+ }
33
+ return [controlKey];
34
+ }
35
+ export function getLinkedControlUpdates({ pair, changedKey, nextValue, values, mins, maxs, }) {
36
+ const [firstKey, secondKey] = pair.controls;
37
+ if (changedKey !== firstKey && changedKey !== secondKey) {
38
+ return { [changedKey]: nextValue };
39
+ }
40
+ const otherKey = changedKey === firstKey ? secondKey : firstKey;
41
+ const currentChanged = values[changedKey];
42
+ const currentOther = values[otherKey];
43
+ const requestedShift = nextValue - currentChanged;
44
+ const minShift = Math.max(mins[changedKey] - currentChanged, mins[otherKey] - currentOther);
45
+ const maxShift = Math.min(maxs[changedKey] - currentChanged, maxs[otherKey] - currentOther);
46
+ const appliedShift = Math.min(Math.max(requestedShift, minShift), maxShift);
47
+ return {
48
+ [changedKey]: currentChanged + appliedShift,
49
+ [otherKey]: currentOther + appliedShift,
50
+ };
51
+ }
@@ -0,0 +1,17 @@
1
+ const cachePromise = caches.open("sound-files");
2
+ export async function loadFromCache(url) {
3
+ const startTime = performance.now();
4
+ const cache = await cachePromise;
5
+ const response = await cache.match(url);
6
+ if (response) {
7
+ console.log(`[cache] Loaded ${url} from CacheStorage in ${(performance.now() - startTime).toFixed(0)}ms`);
8
+ return response.arrayBuffer();
9
+ }
10
+ const fetched = await fetch(url);
11
+ if (fetched.ok) {
12
+ cache.put(url, fetched.clone()).catch(() => { });
13
+ console.log(`[cache] Loaded ${url} from network in ${(performance.now() - startTime).toFixed(0)}ms`);
14
+ return fetched.arrayBuffer();
15
+ }
16
+ return undefined;
17
+ }