@jadujoel/web-audio-clip-node 0.1.1 → 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.
- package/README.md +9 -3
- package/dist/audio/version.d.ts +1 -1
- package/dist/audio/version.js +1 -1
- package/dist/lib.bundle.js +6 -0
- package/dist/lib.bundle.js.map +7 -0
- package/examples/cdn-vanilla/README.md +5 -5
- package/examples/cdn-vanilla/index.html +10 -2
- package/examples/esm-bundler/node_modules/.package-lock.json +1168 -0
- package/examples/esm-bundler/node_modules/@esbuild/darwin-arm64/README.md +3 -0
- package/examples/esm-bundler/node_modules/@esbuild/darwin-arm64/bin/esbuild +0 -0
- package/examples/esm-bundler/node_modules/@esbuild/darwin-arm64/package.json +20 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/LICENSE +21 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/README.md +91 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/ClipNode.d.ts +86 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/ClipNode.js +312 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/processor-code.d.ts +1 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/processor-code.js +2 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/processor-kernel.d.ts +43 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/processor-kernel.js +861 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/processor.d.ts +1 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/processor.js +80 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/types.d.ts +192 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/types.js +9 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/utils.d.ts +22 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/utils.js +128 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/version.d.ts +1 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/version.js +2 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/workletUrl.d.ts +6 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/audio/workletUrl.js +17 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/AudioControl.d.ts +28 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/AudioControl.js +99 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/ContextMenu.d.ts +17 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/ContextMenu.js +73 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/ControlSection.d.ts +26 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/ControlSection.js +74 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/DetuneControl.d.ts +10 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/DetuneControl.js +44 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/DisplayPanel.d.ts +14 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/DisplayPanel.js +6 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/FilterControl.d.ts +12 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/FilterControl.js +48 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/GainControl.d.ts +10 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/GainControl.js +44 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/PanControl.d.ts +10 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/PanControl.js +50 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/PlaybackRateControl.d.ts +10 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/PlaybackRateControl.js +44 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/PlayheadSlider.d.ts +13 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/PlayheadSlider.js +20 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/SnappableSlider.d.ts +18 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/SnappableSlider.js +174 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/TransportButtons.d.ts +14 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/components/TransportButtons.js +9 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/controls/controlDefs.d.ts +31 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/controls/controlDefs.js +211 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/controls/formatValueText.d.ts +2 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/controls/formatValueText.js +80 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/controls/linkedControlPairs.d.ts +20 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/controls/linkedControlPairs.js +51 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/data/cache.d.ts +1 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/data/cache.js +17 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/data/fileStore.d.ts +6 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/data/fileStore.js +39 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/hooks/useClipNode.d.ts +31 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/hooks/useClipNode.js +338 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/lib-react.d.ts +15 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/lib-react.js +17 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/lib.d.ts +16 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/lib.js +16 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/processor.js +4 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/processor.js.map +12 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/store/clipStore.d.ts +63 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/store/clipStore.js +71 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/styles.css +739 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/README.md +10 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/cdn-vanilla/README.md +13 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/cdn-vanilla/index.html +61 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/esm-bundler/README.md +8 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/esm-bundler/index.html +12 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/esm-bundler/package.json +15 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/esm-bundler/src/main.ts +43 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/react/README.md +10 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/react/index.html +12 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/react/package.json +21 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/react/src/App.tsx +20 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/react/src/main.tsx +9 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/self-hosted/README.md +11 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/self-hosted/index.html +12 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/self-hosted/package.json +16 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/self-hosted/public/.gitkeep +1 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/self-hosted/src/main.ts +46 -0
- package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/package.json +88 -0
- package/examples/esm-bundler/node_modules/@rollup/rollup-darwin-arm64/README.md +3 -0
- package/examples/esm-bundler/node_modules/@rollup/rollup-darwin-arm64/package.json +22 -0
- package/examples/esm-bundler/node_modules/@rollup/rollup-darwin-arm64/rollup.darwin-arm64.node +0 -0
- package/examples/esm-bundler/node_modules/@types/estree/LICENSE +21 -0
- package/examples/esm-bundler/node_modules/@types/estree/README.md +15 -0
- package/examples/esm-bundler/node_modules/@types/estree/flow.d.ts +167 -0
- package/examples/esm-bundler/node_modules/@types/estree/index.d.ts +694 -0
- package/examples/esm-bundler/node_modules/@types/estree/package.json +27 -0
- package/examples/esm-bundler/node_modules/esbuild/LICENSE.md +21 -0
- package/examples/esm-bundler/node_modules/esbuild/README.md +3 -0
- package/examples/esm-bundler/node_modules/esbuild/bin/esbuild +0 -0
- package/examples/esm-bundler/node_modules/esbuild/install.js +289 -0
- package/examples/esm-bundler/node_modules/esbuild/lib/main.d.ts +716 -0
- package/examples/esm-bundler/node_modules/esbuild/lib/main.js +2242 -0
- package/examples/esm-bundler/node_modules/esbuild/package.json +49 -0
- package/examples/esm-bundler/node_modules/fdir/LICENSE +7 -0
- package/examples/esm-bundler/node_modules/fdir/README.md +91 -0
- package/examples/esm-bundler/node_modules/fdir/dist/index.cjs +588 -0
- package/examples/esm-bundler/node_modules/fdir/dist/index.d.cts +155 -0
- package/examples/esm-bundler/node_modules/fdir/dist/index.d.mts +155 -0
- package/examples/esm-bundler/node_modules/fdir/dist/index.mjs +570 -0
- package/examples/esm-bundler/node_modules/fdir/package.json +103 -0
- package/examples/esm-bundler/node_modules/nanoid/LICENSE +20 -0
- package/examples/esm-bundler/node_modules/nanoid/README.md +39 -0
- package/examples/esm-bundler/node_modules/nanoid/async/index.browser.cjs +69 -0
- package/examples/esm-bundler/node_modules/nanoid/async/index.browser.js +34 -0
- package/examples/esm-bundler/node_modules/nanoid/async/index.cjs +71 -0
- package/examples/esm-bundler/node_modules/nanoid/async/index.d.ts +56 -0
- package/examples/esm-bundler/node_modules/nanoid/async/index.js +35 -0
- package/examples/esm-bundler/node_modules/nanoid/async/index.native.js +26 -0
- package/examples/esm-bundler/node_modules/nanoid/async/package.json +12 -0
- package/examples/esm-bundler/node_modules/nanoid/bin/nanoid.cjs +55 -0
- package/examples/esm-bundler/node_modules/nanoid/index.browser.cjs +72 -0
- package/examples/esm-bundler/node_modules/nanoid/index.browser.js +34 -0
- package/examples/esm-bundler/node_modules/nanoid/index.cjs +85 -0
- package/examples/esm-bundler/node_modules/nanoid/index.d.cts +91 -0
- package/examples/esm-bundler/node_modules/nanoid/index.d.ts +91 -0
- package/examples/esm-bundler/node_modules/nanoid/index.js +45 -0
- package/examples/esm-bundler/node_modules/nanoid/nanoid.js +1 -0
- package/examples/esm-bundler/node_modules/nanoid/non-secure/index.cjs +34 -0
- package/examples/esm-bundler/node_modules/nanoid/non-secure/index.d.ts +33 -0
- package/examples/esm-bundler/node_modules/nanoid/non-secure/index.js +21 -0
- package/examples/esm-bundler/node_modules/nanoid/non-secure/package.json +6 -0
- package/examples/esm-bundler/node_modules/nanoid/package.json +89 -0
- package/examples/esm-bundler/node_modules/nanoid/url-alphabet/index.cjs +7 -0
- package/examples/esm-bundler/node_modules/nanoid/url-alphabet/index.js +3 -0
- package/examples/esm-bundler/node_modules/nanoid/url-alphabet/package.json +6 -0
- package/examples/esm-bundler/node_modules/picocolors/LICENSE +15 -0
- package/examples/esm-bundler/node_modules/picocolors/README.md +21 -0
- package/examples/esm-bundler/node_modules/picocolors/package.json +25 -0
- package/examples/esm-bundler/node_modules/picocolors/picocolors.browser.js +4 -0
- package/examples/esm-bundler/node_modules/picocolors/picocolors.d.ts +5 -0
- package/examples/esm-bundler/node_modules/picocolors/picocolors.js +75 -0
- package/examples/esm-bundler/node_modules/picocolors/types.d.ts +51 -0
- package/examples/esm-bundler/node_modules/picomatch/LICENSE +21 -0
- package/examples/esm-bundler/node_modules/picomatch/README.md +749 -0
- package/examples/esm-bundler/node_modules/picomatch/index.js +17 -0
- package/examples/esm-bundler/node_modules/picomatch/lib/constants.js +184 -0
- package/examples/esm-bundler/node_modules/picomatch/lib/parse.js +1386 -0
- package/examples/esm-bundler/node_modules/picomatch/lib/picomatch.js +349 -0
- package/examples/esm-bundler/node_modules/picomatch/lib/scan.js +391 -0
- package/examples/esm-bundler/node_modules/picomatch/lib/utils.js +72 -0
- package/examples/esm-bundler/node_modules/picomatch/package.json +82 -0
- package/examples/esm-bundler/node_modules/picomatch/posix.js +3 -0
- package/examples/esm-bundler/node_modules/postcss/LICENSE +20 -0
- package/examples/esm-bundler/node_modules/postcss/README.md +28 -0
- package/examples/esm-bundler/node_modules/postcss/lib/at-rule.d.ts +139 -0
- package/examples/esm-bundler/node_modules/postcss/lib/at-rule.js +25 -0
- package/examples/esm-bundler/node_modules/postcss/lib/comment.d.ts +67 -0
- package/examples/esm-bundler/node_modules/postcss/lib/comment.js +13 -0
- package/examples/esm-bundler/node_modules/postcss/lib/container.d.ts +478 -0
- package/examples/esm-bundler/node_modules/postcss/lib/container.js +447 -0
- package/examples/esm-bundler/node_modules/postcss/lib/css-syntax-error.d.ts +247 -0
- package/examples/esm-bundler/node_modules/postcss/lib/css-syntax-error.js +133 -0
- package/examples/esm-bundler/node_modules/postcss/lib/declaration.d.ts +150 -0
- package/examples/esm-bundler/node_modules/postcss/lib/declaration.js +24 -0
- package/examples/esm-bundler/node_modules/postcss/lib/document.d.ts +68 -0
- package/examples/esm-bundler/node_modules/postcss/lib/document.js +33 -0
- package/examples/esm-bundler/node_modules/postcss/lib/fromJSON.d.ts +9 -0
- package/examples/esm-bundler/node_modules/postcss/lib/fromJSON.js +54 -0
- package/examples/esm-bundler/node_modules/postcss/lib/input.d.ts +226 -0
- package/examples/esm-bundler/node_modules/postcss/lib/input.js +273 -0
- package/examples/esm-bundler/node_modules/postcss/lib/lazy-result.d.ts +189 -0
- package/examples/esm-bundler/node_modules/postcss/lib/lazy-result.js +550 -0
- package/examples/esm-bundler/node_modules/postcss/lib/list.d.ts +60 -0
- package/examples/esm-bundler/node_modules/postcss/lib/list.js +58 -0
- package/examples/esm-bundler/node_modules/postcss/lib/map-generator.js +376 -0
- package/examples/esm-bundler/node_modules/postcss/lib/no-work-result.d.ts +45 -0
- package/examples/esm-bundler/node_modules/postcss/lib/no-work-result.js +137 -0
- package/examples/esm-bundler/node_modules/postcss/lib/node.d.ts +555 -0
- package/examples/esm-bundler/node_modules/postcss/lib/node.js +449 -0
- package/examples/esm-bundler/node_modules/postcss/lib/parse.d.ts +9 -0
- package/examples/esm-bundler/node_modules/postcss/lib/parse.js +42 -0
- package/examples/esm-bundler/node_modules/postcss/lib/parser.js +611 -0
- package/examples/esm-bundler/node_modules/postcss/lib/postcss.d.mts +66 -0
- package/examples/esm-bundler/node_modules/postcss/lib/postcss.d.ts +456 -0
- package/examples/esm-bundler/node_modules/postcss/lib/postcss.js +101 -0
- package/examples/esm-bundler/node_modules/postcss/lib/postcss.mjs +30 -0
- package/examples/esm-bundler/node_modules/postcss/lib/previous-map.d.ts +80 -0
- package/examples/esm-bundler/node_modules/postcss/lib/previous-map.js +145 -0
- package/examples/esm-bundler/node_modules/postcss/lib/processor.d.ts +114 -0
- package/examples/esm-bundler/node_modules/postcss/lib/processor.js +67 -0
- package/examples/esm-bundler/node_modules/postcss/lib/result.d.ts +204 -0
- package/examples/esm-bundler/node_modules/postcss/lib/result.js +42 -0
- package/examples/esm-bundler/node_modules/postcss/lib/root.d.ts +86 -0
- package/examples/esm-bundler/node_modules/postcss/lib/root.js +61 -0
- package/examples/esm-bundler/node_modules/postcss/lib/rule.d.ts +126 -0
- package/examples/esm-bundler/node_modules/postcss/lib/rule.js +27 -0
- package/examples/esm-bundler/node_modules/postcss/lib/stringifier.d.ts +45 -0
- package/examples/esm-bundler/node_modules/postcss/lib/stringifier.js +353 -0
- package/examples/esm-bundler/node_modules/postcss/lib/stringify.d.ts +9 -0
- package/examples/esm-bundler/node_modules/postcss/lib/stringify.js +11 -0
- package/examples/esm-bundler/node_modules/postcss/lib/symbols.js +5 -0
- package/examples/esm-bundler/node_modules/postcss/lib/terminal-highlight.js +70 -0
- package/examples/esm-bundler/node_modules/postcss/lib/tokenize.js +266 -0
- package/examples/esm-bundler/node_modules/postcss/lib/warn-once.js +13 -0
- package/examples/esm-bundler/node_modules/postcss/lib/warning.d.ts +146 -0
- package/examples/esm-bundler/node_modules/postcss/lib/warning.js +37 -0
- package/examples/esm-bundler/node_modules/postcss/package.json +88 -0
- package/examples/esm-bundler/node_modules/rollup/LICENSE.md +679 -0
- package/examples/esm-bundler/node_modules/rollup/README.md +134 -0
- package/examples/esm-bundler/node_modules/rollup/dist/bin/rollup +1912 -0
- package/examples/esm-bundler/node_modules/rollup/dist/es/getLogFilter.js +64 -0
- package/examples/esm-bundler/node_modules/rollup/dist/es/package.json +1 -0
- package/examples/esm-bundler/node_modules/rollup/dist/es/parseAst.js +12 -0
- package/examples/esm-bundler/node_modules/rollup/dist/es/rollup.js +17 -0
- package/examples/esm-bundler/node_modules/rollup/dist/es/shared/node-entry.js +24463 -0
- package/examples/esm-bundler/node_modules/rollup/dist/es/shared/parseAst.js +2124 -0
- package/examples/esm-bundler/node_modules/rollup/dist/es/shared/watch.js +9909 -0
- package/examples/esm-bundler/node_modules/rollup/dist/getLogFilter.d.ts +5 -0
- package/examples/esm-bundler/node_modules/rollup/dist/getLogFilter.js +69 -0
- package/examples/esm-bundler/node_modules/rollup/dist/loadConfigFile.d.ts +20 -0
- package/examples/esm-bundler/node_modules/rollup/dist/loadConfigFile.js +29 -0
- package/examples/esm-bundler/node_modules/rollup/dist/native.js +161 -0
- package/examples/esm-bundler/node_modules/rollup/dist/parseAst.d.ts +4 -0
- package/examples/esm-bundler/node_modules/rollup/dist/parseAst.js +22 -0
- package/examples/esm-bundler/node_modules/rollup/dist/rollup.d.ts +1225 -0
- package/examples/esm-bundler/node_modules/rollup/dist/rollup.js +127 -0
- package/examples/esm-bundler/node_modules/rollup/dist/shared/fsevents-importer.js +37 -0
- package/examples/esm-bundler/node_modules/rollup/dist/shared/index.js +9615 -0
- package/examples/esm-bundler/node_modules/rollup/dist/shared/loadConfigFile.js +572 -0
- package/examples/esm-bundler/node_modules/rollup/dist/shared/parseAst.js +2361 -0
- package/examples/esm-bundler/node_modules/rollup/dist/shared/rollup.js +24385 -0
- package/examples/esm-bundler/node_modules/rollup/dist/shared/watch-cli.js +542 -0
- package/examples/esm-bundler/node_modules/rollup/dist/shared/watch.js +324 -0
- package/examples/esm-bundler/node_modules/rollup/package.json +289 -0
- package/examples/esm-bundler/node_modules/source-map-js/LICENSE +28 -0
- package/examples/esm-bundler/node_modules/source-map-js/README.md +765 -0
- package/examples/esm-bundler/node_modules/source-map-js/lib/array-set.js +121 -0
- package/examples/esm-bundler/node_modules/source-map-js/lib/base64-vlq.js +140 -0
- package/examples/esm-bundler/node_modules/source-map-js/lib/base64.js +67 -0
- package/examples/esm-bundler/node_modules/source-map-js/lib/binary-search.js +111 -0
- package/examples/esm-bundler/node_modules/source-map-js/lib/mapping-list.js +79 -0
- package/examples/esm-bundler/node_modules/source-map-js/lib/quick-sort.js +132 -0
- package/examples/esm-bundler/node_modules/source-map-js/lib/source-map-consumer.d.ts +1 -0
- package/examples/esm-bundler/node_modules/source-map-js/lib/source-map-consumer.js +1188 -0
- package/examples/esm-bundler/node_modules/source-map-js/lib/source-map-generator.d.ts +1 -0
- package/examples/esm-bundler/node_modules/source-map-js/lib/source-map-generator.js +444 -0
- package/examples/esm-bundler/node_modules/source-map-js/lib/source-node.d.ts +1 -0
- package/examples/esm-bundler/node_modules/source-map-js/lib/source-node.js +413 -0
- package/examples/esm-bundler/node_modules/source-map-js/lib/util.js +594 -0
- package/examples/esm-bundler/node_modules/source-map-js/package.json +71 -0
- package/examples/esm-bundler/node_modules/source-map-js/source-map.d.ts +104 -0
- package/examples/esm-bundler/node_modules/source-map-js/source-map.js +8 -0
- package/examples/esm-bundler/node_modules/tinyglobby/LICENSE +21 -0
- package/examples/esm-bundler/node_modules/tinyglobby/README.md +25 -0
- package/examples/esm-bundler/node_modules/tinyglobby/dist/index.cjs +334 -0
- package/examples/esm-bundler/node_modules/tinyglobby/dist/index.d.cts +148 -0
- package/examples/esm-bundler/node_modules/tinyglobby/dist/index.d.mts +148 -0
- package/examples/esm-bundler/node_modules/tinyglobby/dist/index.mjs +306 -0
- package/examples/esm-bundler/node_modules/tinyglobby/package.json +73 -0
- package/examples/esm-bundler/node_modules/vite/LICENSE.md +2406 -0
- package/examples/esm-bundler/node_modules/vite/README.md +20 -0
- package/examples/esm-bundler/node_modules/vite/bin/openChrome.applescript +95 -0
- package/examples/esm-bundler/node_modules/vite/bin/vite.js +79 -0
- package/examples/esm-bundler/node_modules/vite/client.d.ts +279 -0
- package/examples/esm-bundler/node_modules/vite/dist/client/client.mjs +1134 -0
- package/examples/esm-bundler/node_modules/vite/dist/client/env.mjs +24 -0
- package/examples/esm-bundler/node_modules/vite/dist/node/chunks/dep-3RmXg9uo.js +553 -0
- package/examples/esm-bundler/node_modules/vite/dist/node/chunks/dep-4-IQbZQm.js +822 -0
- package/examples/esm-bundler/node_modules/vite/dist/node/chunks/dep-CvfTChi5.js +8218 -0
- package/examples/esm-bundler/node_modules/vite/dist/node/chunks/dep-Dq2t6Dq0.js +49565 -0
- package/examples/esm-bundler/node_modules/vite/dist/node/chunks/dep-lpEPC2f9.js +7113 -0
- package/examples/esm-bundler/node_modules/vite/dist/node/cli.js +949 -0
- package/examples/esm-bundler/node_modules/vite/dist/node/constants.js +149 -0
- package/examples/esm-bundler/node_modules/vite/dist/node/index.d.ts +4227 -0
- package/examples/esm-bundler/node_modules/vite/dist/node/index.js +194 -0
- package/examples/esm-bundler/node_modules/vite/dist/node/module-runner.d.ts +290 -0
- package/examples/esm-bundler/node_modules/vite/dist/node/module-runner.js +1311 -0
- package/examples/esm-bundler/node_modules/vite/dist/node/moduleRunnerTransport.d-DJ_mE5sf.d.ts +87 -0
- package/examples/esm-bundler/node_modules/vite/dist/node-cjs/publicUtils.cjs +3987 -0
- package/examples/esm-bundler/node_modules/vite/index.cjs +96 -0
- package/examples/esm-bundler/node_modules/vite/index.d.cts +6 -0
- package/examples/esm-bundler/node_modules/vite/misc/false.js +1 -0
- package/examples/esm-bundler/node_modules/vite/misc/true.js +1 -0
- package/examples/esm-bundler/node_modules/vite/package.json +204 -0
- package/examples/esm-bundler/node_modules/vite/types/customEvent.d.ts +45 -0
- package/examples/esm-bundler/node_modules/vite/types/hmrPayload.d.ts +74 -0
- package/examples/esm-bundler/node_modules/vite/types/hot.d.ts +39 -0
- package/examples/esm-bundler/node_modules/vite/types/import-meta.d.ts +5 -0
- package/examples/esm-bundler/node_modules/vite/types/importGlob.d.ts +75 -0
- package/examples/esm-bundler/node_modules/vite/types/importMeta.d.ts +31 -0
- package/examples/esm-bundler/node_modules/vite/types/internal/cssPreprocessorOptions.d.ts +63 -0
- package/examples/esm-bundler/node_modules/vite/types/internal/lightningcssOptions.d.ts +18 -0
- package/examples/esm-bundler/node_modules/vite/types/metadata.d.ts +35 -0
- package/examples/esm-bundler/node_modules/vite/types/package.json +4 -0
- package/examples/esm-bundler/package-lock.json +1127 -0
- package/examples/esm-bundler/src/main.ts +22 -22
- package/examples/react/README.md +2 -2
- package/examples/react/package.json +3 -5
- package/examples/self-hosted/src/main.ts +24 -24
- package/package.json +2 -1
- /package/examples/{react → esm-bundler/node_modules/@jadujoel/web-audio-clip-node/examples/react}/vite.config.ts +0 -0
|
@@ -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,14 @@
|
|
|
1
|
+
import type { ClipNodeState } from "../audio/types";
|
|
2
|
+
interface TransportButtonsProps {
|
|
3
|
+
nodeState: ClipNodeState;
|
|
4
|
+
onStart: () => void;
|
|
5
|
+
onStop: () => void;
|
|
6
|
+
onPause: () => void;
|
|
7
|
+
onResume: () => void;
|
|
8
|
+
onDispose: () => void;
|
|
9
|
+
onLog: () => void;
|
|
10
|
+
onLoadSound: () => void;
|
|
11
|
+
}
|
|
12
|
+
declare function TransportButtonsInner({ nodeState, onStart, onStop, onPause, onResume, onDispose, onLog, onLoadSound, }: TransportButtonsProps): import("react/jsx-runtime").JSX.Element;
|
|
13
|
+
export declare const TransportButtons: import("react").MemoExoticComponent<typeof TransportButtonsInner>;
|
|
14
|
+
export {};
|
|
@@ -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,31 @@
|
|
|
1
|
+
export type ControlKey = "playhead" | "offset" | "duration" | "startDelay" | "stopDelay" | "fadeIn" | "fadeOut" | "loopStart" | "loopEnd" | "loopCrossfade" | "playbackRate" | "detune" | "gain" | "pan" | "lowpass" | "highpass";
|
|
2
|
+
export interface ControlDef {
|
|
3
|
+
key: ControlKey;
|
|
4
|
+
label: string;
|
|
5
|
+
min: number;
|
|
6
|
+
max: number;
|
|
7
|
+
defaultValue: number;
|
|
8
|
+
precision?: number;
|
|
9
|
+
snap?: string;
|
|
10
|
+
preset?: string;
|
|
11
|
+
title?: string;
|
|
12
|
+
hasToggle?: boolean;
|
|
13
|
+
hasSnap?: boolean;
|
|
14
|
+
hasMaxLock?: boolean;
|
|
15
|
+
/** When true, max defaults to audio file duration. */
|
|
16
|
+
maxLockedByDefault?: boolean;
|
|
17
|
+
}
|
|
18
|
+
export declare const DEFAULT_TEMPO = 120;
|
|
19
|
+
export declare const SAMPLE_RATE = 48000;
|
|
20
|
+
export declare const controlDefs: ControlDef[];
|
|
21
|
+
export declare const loopControlDefs: ControlDef[];
|
|
22
|
+
export declare const paramDefs: ControlDef[];
|
|
23
|
+
export declare const allDefs: ControlDef[];
|
|
24
|
+
export declare function buildDefaults(): {
|
|
25
|
+
values: Record<ControlKey, number>;
|
|
26
|
+
snaps: Record<ControlKey, string>;
|
|
27
|
+
enabled: Record<ControlKey, boolean>;
|
|
28
|
+
mins: Record<ControlKey, number>;
|
|
29
|
+
maxs: Record<ControlKey, number>;
|
|
30
|
+
maxLocked: Record<ControlKey, boolean>;
|
|
31
|
+
};
|
package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/controls/controlDefs.js
ADDED
|
@@ -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,20 @@
|
|
|
1
|
+
import type { ControlKey } from "./controlDefs";
|
|
2
|
+
export type LinkedControlPairKey = "fadeOutStopDelay" | "loopStartEnd";
|
|
3
|
+
export interface LinkedControlPairDef {
|
|
4
|
+
key: LinkedControlPairKey;
|
|
5
|
+
label: string;
|
|
6
|
+
controls: readonly [ControlKey, ControlKey];
|
|
7
|
+
}
|
|
8
|
+
export declare const transportLinkedControlPairs: readonly LinkedControlPairDef[];
|
|
9
|
+
export declare const loopLinkedControlPairs: readonly LinkedControlPairDef[];
|
|
10
|
+
export declare function buildLinkedControlPairDefaults(): Record<LinkedControlPairKey, boolean>;
|
|
11
|
+
export declare function getLinkedControlPairForControl(controlKey: ControlKey): LinkedControlPairDef | undefined;
|
|
12
|
+
export declare function getActiveLinkedControls(controlKey: ControlKey, linkedPairs: Record<LinkedControlPairKey, boolean>): readonly ControlKey[];
|
|
13
|
+
export declare function getLinkedControlUpdates({ pair, changedKey, nextValue, values, mins, maxs, }: {
|
|
14
|
+
pair: LinkedControlPairDef;
|
|
15
|
+
changedKey: ControlKey;
|
|
16
|
+
nextValue: number;
|
|
17
|
+
values: Record<ControlKey, number>;
|
|
18
|
+
mins: Record<ControlKey, number>;
|
|
19
|
+
maxs: Record<ControlKey, number>;
|
|
20
|
+
}): Partial<Record<ControlKey, number>>;
|
|
@@ -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 @@
|
|
|
1
|
+
export declare function loadFromCache(url: string): Promise<ArrayBuffer | undefined>;
|
|
@@ -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
|
+
}
|
package/examples/esm-bundler/node_modules/@jadujoel/web-audio-clip-node/dist/data/fileStore.js
ADDED
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
const DB_NAME = "clip-audio-store";
|
|
2
|
+
const DB_VERSION = 1;
|
|
3
|
+
const STORE_NAME = "files";
|
|
4
|
+
const LAST_FILE_KEY = "last-uploaded";
|
|
5
|
+
function openDB() {
|
|
6
|
+
return new Promise((resolve, reject) => {
|
|
7
|
+
const request = indexedDB.open(DB_NAME, DB_VERSION);
|
|
8
|
+
request.onupgradeneeded = () => {
|
|
9
|
+
const db = request.result;
|
|
10
|
+
if (!db.objectStoreNames.contains(STORE_NAME)) {
|
|
11
|
+
db.createObjectStore(STORE_NAME);
|
|
12
|
+
}
|
|
13
|
+
};
|
|
14
|
+
request.onsuccess = () => resolve(request.result);
|
|
15
|
+
request.onerror = () => reject(request.error);
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
function tx(db, mode) {
|
|
19
|
+
return db.transaction(STORE_NAME, mode).objectStore(STORE_NAME);
|
|
20
|
+
}
|
|
21
|
+
export async function saveUploadedFile(name, arrayBuffer) {
|
|
22
|
+
const db = await openDB();
|
|
23
|
+
const store = tx(db, "readwrite");
|
|
24
|
+
const data = { name, arrayBuffer };
|
|
25
|
+
await new Promise((resolve, reject) => {
|
|
26
|
+
const req = store.put(data, LAST_FILE_KEY);
|
|
27
|
+
req.onsuccess = () => resolve();
|
|
28
|
+
req.onerror = () => reject(req.error);
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
export async function loadUploadedFile() {
|
|
32
|
+
const db = await openDB();
|
|
33
|
+
const store = tx(db, "readonly");
|
|
34
|
+
return new Promise((resolve, reject) => {
|
|
35
|
+
const req = store.get(LAST_FILE_KEY);
|
|
36
|
+
req.onsuccess = () => resolve(req.result ?? null);
|
|
37
|
+
req.onerror = () => reject(req.error);
|
|
38
|
+
});
|
|
39
|
+
}
|