@tsparticles/plugin-sounds 3.0.3 → 3.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/265.min.js +2 -0
- package/265.min.js.LICENSE.txt +1 -0
- package/714.min.js +2 -0
- package/714.min.js.LICENSE.txt +1 -0
- package/browser/Options/Classes/Sounds.js +4 -0
- package/browser/Options/Classes/SoundsEvent.js +4 -3
- package/browser/Options/Classes/SoundsIcon.js +1 -0
- package/browser/Options/Classes/SoundsIcons.js +4 -0
- package/browser/SoundsInstance.js +130 -69
- package/browser/SoundsPlugin.js +37 -0
- package/browser/index.js +1 -24
- package/browser/utils.js +11 -4
- package/cjs/Options/Classes/Sounds.js +4 -0
- package/cjs/Options/Classes/SoundsEvent.js +4 -3
- package/cjs/Options/Classes/SoundsIcon.js +1 -0
- package/cjs/Options/Classes/SoundsIcons.js +4 -0
- package/cjs/SoundsInstance.js +128 -67
- package/cjs/SoundsPlugin.js +64 -0
- package/cjs/index.js +24 -24
- package/cjs/utils.js +14 -5
- package/dist_browser_SoundsInstance_js.js +30 -0
- package/dist_browser_SoundsPlugin_js.js +120 -0
- package/esm/Options/Classes/Sounds.js +4 -0
- package/esm/Options/Classes/SoundsEvent.js +4 -3
- package/esm/Options/Classes/SoundsIcon.js +1 -0
- package/esm/Options/Classes/SoundsIcons.js +4 -0
- package/esm/SoundsInstance.js +130 -69
- package/esm/SoundsPlugin.js +37 -0
- package/esm/index.js +1 -24
- package/esm/utils.js +11 -4
- package/package.json +2 -2
- package/report.html +3 -3
- package/tsparticles.plugin.sounds.js +241 -738
- package/tsparticles.plugin.sounds.min.js +1 -1
- package/tsparticles.plugin.sounds.min.js.LICENSE.txt +1 -1
- package/types/Options/Classes/Sounds.d.ts +1 -0
- package/types/Options/Classes/SoundsEvent.d.ts +0 -5
- package/types/Options/Classes/SoundsIcon.d.ts +1 -0
- package/types/Options/Classes/SoundsIcons.d.ts +1 -0
- package/types/Options/Interfaces/ISounds.d.ts +1 -0
- package/types/Options/Interfaces/ISoundsIcon.d.ts +1 -0
- package/types/Options/Interfaces/ISoundsIcons.d.ts +1 -0
- package/types/SoundsInstance.d.ts +6 -0
- package/types/SoundsPlugin.d.ts +11 -0
- package/types/index.d.ts +1 -1
- package/types/types.d.ts +5 -5
- package/types/utils.d.ts +2 -0
- package/umd/Options/Classes/Sounds.js +4 -0
- package/umd/Options/Classes/SoundsEvent.js +4 -3
- package/umd/Options/Classes/SoundsIcon.js +1 -0
- package/umd/Options/Classes/SoundsIcons.js +4 -0
- package/umd/SoundsInstance.js +128 -67
- package/umd/SoundsPlugin.js +75 -0
- package/umd/index.js +26 -25
- package/umd/utils.js +14 -5
package/esm/index.js
CHANGED
|
@@ -1,27 +1,4 @@
|
|
|
1
|
-
import { Sounds } from "./Options/Classes/Sounds.js";
|
|
2
|
-
import { SoundsInstance } from "./SoundsInstance.js";
|
|
3
|
-
class SoundsPlugin {
|
|
4
|
-
constructor(engine) {
|
|
5
|
-
this.id = "sounds";
|
|
6
|
-
this._engine = engine;
|
|
7
|
-
}
|
|
8
|
-
getPlugin(container) {
|
|
9
|
-
return new SoundsInstance(container, this._engine);
|
|
10
|
-
}
|
|
11
|
-
loadOptions(options, source) {
|
|
12
|
-
if (!this.needsPlugin(options) && !this.needsPlugin(source)) {
|
|
13
|
-
return;
|
|
14
|
-
}
|
|
15
|
-
let soundsOptions = options.sounds;
|
|
16
|
-
if (soundsOptions?.load === undefined) {
|
|
17
|
-
options.sounds = soundsOptions = new Sounds();
|
|
18
|
-
}
|
|
19
|
-
soundsOptions.load(source?.sounds);
|
|
20
|
-
}
|
|
21
|
-
needsPlugin(options) {
|
|
22
|
-
return options?.sounds?.enable ?? false;
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
1
|
export async function loadSoundsPlugin(engine, refresh = true) {
|
|
2
|
+
const { SoundsPlugin } = await import("./SoundsPlugin.js");
|
|
26
3
|
await engine.addPlugin(new SoundsPlugin(engine), refresh);
|
|
27
4
|
}
|
package/esm/utils.js
CHANGED
|
@@ -13,13 +13,20 @@ notes.set("Bb", [29.14, 58.27, 116.54, 233.08, 466.16, 932.33, 1864.66, 3729.31,
|
|
|
13
13
|
notes.set("B", [30.87, 61.74, 123.47, 246.94, 493.88, 987.77, 1975.53, 3951.07, 7902.13]);
|
|
14
14
|
notes.set("pause", [0]);
|
|
15
15
|
export function getNoteFrequency(note) {
|
|
16
|
-
const regex = /(([A-G]b?)(\d))|pause/i, result = regex.exec(note);
|
|
17
|
-
if (!result
|
|
16
|
+
const regex = /(([A-G]b?)(\d))|pause/i, result = regex.exec(note), groupKey = 2, defaultMatchKey = 0, innerGroupKey = 3;
|
|
17
|
+
if (!result?.length) {
|
|
18
18
|
return;
|
|
19
19
|
}
|
|
20
|
-
const noteKey = result[
|
|
20
|
+
const noteKey = result[groupKey] || result[defaultMatchKey], noteItem = notes.get(noteKey);
|
|
21
21
|
if (!noteItem) {
|
|
22
22
|
return;
|
|
23
23
|
}
|
|
24
|
-
return noteItem[parseInt(result[
|
|
24
|
+
return noteItem[parseInt(result[innerGroupKey] || "0")];
|
|
25
25
|
}
|
|
26
|
+
let muted = true;
|
|
27
|
+
export const isWindowMuted = () => {
|
|
28
|
+
return muted;
|
|
29
|
+
};
|
|
30
|
+
export const unmuteWindow = () => {
|
|
31
|
+
muted = false;
|
|
32
|
+
};
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@tsparticles/plugin-sounds",
|
|
3
|
-
"version": "3.0
|
|
3
|
+
"version": "3.2.0",
|
|
4
4
|
"description": "tsParticles sounds plugin",
|
|
5
5
|
"homepage": "https://particles.js.org",
|
|
6
6
|
"repository": {
|
|
@@ -86,7 +86,7 @@
|
|
|
86
86
|
"./package.json": "./package.json"
|
|
87
87
|
},
|
|
88
88
|
"dependencies": {
|
|
89
|
-
"@tsparticles/engine": "^3.0
|
|
89
|
+
"@tsparticles/engine": "^3.2.0"
|
|
90
90
|
},
|
|
91
91
|
"publishConfig": {
|
|
92
92
|
"access": "public"
|
package/report.html
CHANGED
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
<head>
|
|
4
4
|
<meta charset="UTF-8"/>
|
|
5
5
|
<meta name="viewport" content="width=device-width, initial-scale=1"/>
|
|
6
|
-
<title>@tsparticles/plugin-sounds [
|
|
6
|
+
<title>@tsparticles/plugin-sounds [31 Jan 2024 at 02:08]</title>
|
|
7
7
|
<link rel="shortcut icon" href="" type="image/x-icon" />
|
|
8
8
|
|
|
9
9
|
<script>
|
|
@@ -31,8 +31,8 @@
|
|
|
31
31
|
<body>
|
|
32
32
|
<div id="app"></div>
|
|
33
33
|
<script>
|
|
34
|
-
window.chartData = [
|
|
35
|
-
window.entrypoints = ["tsparticles.plugin.sounds
|
|
34
|
+
window.chartData = [];
|
|
35
|
+
window.entrypoints = ["tsparticles.plugin.sounds.min"];
|
|
36
36
|
window.defaultSizes = "parsed";
|
|
37
37
|
</script>
|
|
38
38
|
</body>
|