You're Invited:Meet the Socket Team at BlackHat and DEF CON in Las Vegas, Aug 4-6.RSVP
Socket
Book a DemoInstallSign in
Socket

react-voice-visualizer

Package Overview
Dependencies
Maintainers
1
Versions
44
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

react-voice-visualizer - npm Package Compare versions

Comparing version

to
1.3.2

650

dist/react-voice-visualizer.js
(function(){"use strict";(e=>{try{if(typeof window>"u")return;var i=document.createElement("style");i.appendChild(document.createTextNode(e)),document.head.appendChild(i)}catch(o){console.error("vite-plugin-css-injected-by-js",o)}})(".voice-visualizer__buttons-container{display:flex;justify-content:center;align-items:center;column-gap:20px;row-gap:15px;flex-wrap:wrap;margin-bottom:40px}.voice-visualizer__btn-center{box-sizing:border-box;flex-shrink:0;width:60px;height:60px;padding:0;display:flex;justify-content:center;align-items:center;border-radius:50%;background-color:#fff;border:4px solid #c5c5c5;outline:none;cursor:pointer;transition:border-color .3s,background-color .3s}.voice-visualizer__btn-center:hover{background-color:#eaeaea}.voice-visualizer__btn-center>img{width:auto;height:50%;max-height:30px}.voice-visualizer__btn-center.voice-visualizer__btn-center-pause{background-color:#ff3030}.voice-visualizer__btn-center.voice-visualizer__btn-center-pause:hover{background-color:#ff4f4f}.voice-visualizer__btn-center.voice-visualizer__btn-center-pause>img{height:50%;max-height:16px}.voice-visualizer__btn-center:hover{border:4px solid #9f9f9f}.voice-visualizer__btn-left{box-sizing:border-box;flex-shrink:0;width:60px;height:60px;padding:0;display:flex;justify-content:center;align-items:center;border-radius:50%;background-color:#ff3030;border:4px solid #c5c5c5;outline:none;cursor:pointer;transition:border-color .3s,background-color .3s,opacity .3s}.voice-visualizer__btn-left:hover{background-color:#ff4f4f}.voice-visualizer__btn-left:disabled{opacity:.6;background-color:#ff3030}.voice-visualizer__btn-left.voice-visualizer__btn-left-microphone{background-color:#fff}.voice-visualizer__btn-left.voice-visualizer__btn-left-microphone>img{width:auto;height:50%;max-height:30px}.voice-visualizer__btn-left>img{width:auto;height:50%;max-height:16px}.voice-visualizer__btn-left:hover{border:4px solid #9f9f9f}.voice-visualizer__btn{box-sizing:border-box;min-width:100px;min-height:60px;padding:5px 20px;border-radius:40px;font-size:15px;background-color:#f0f0f0;transition:background-color .3s,opacity .3s}.voice-visualizer__btn:disabled{opacity:.8;background-color:#f0f0f0}.voice-visualizer__btn:hover{background-color:#bebebe}.voice-visualizer__canvas-container{position:relative;width:fit-content;margin:0 auto;overflow:hidden}.voice-visualizer__canvas-container canvas{display:block}.voice-visualizer__canvas-microphone-btn{position:absolute;top:50%;left:50%;width:auto;max-width:12%;min-width:24px;height:50%;max-height:100px;background-color:transparent;border:none;outline:none;transform:translate(-50%,-50%)}.voice-visualizer__canvas-microphone-icon{width:100%;height:100%;will-change:transform;transition:transform .35s}.voice-visualizer__canvas-microphone-btn:hover .voice-visualizer__canvas-microphone-icon{transform:scale(1.03)}.voice-visualizer__canvas-audio-wave-icon{position:absolute;top:50%;left:50%;width:auto;max-width:40%;height:40%;max-height:100px;transform:translate(-118%,-50%) scale(-1)}.voice-visualizer__canvas-audio-wave-icon2{transform:translate(18%,-50%)}.voice-visualizer__canvas-audio-processing{position:absolute;top:50%;left:50%;margin:0;transform:translate(-50%,-50%)}.voice-visualizer__progress-indicator-hovered{position:absolute;top:0;pointer-events:none;height:100%;width:1px;background-color:#85858599}.voice-visualizer__progress-indicator-hovered-time{position:absolute;top:3%;left:1px;width:fit-content;margin:0;padding:0 7px;opacity:.8;font-size:12px;border-radius:0 4px 4px 0;background-color:#575757;text-align:left}.voice-visualizer__progress-indicator-hovered-time.voice-visualizer__progress-indicator-hovered-time-left{left:unset;right:1px;border-radius:4px 0 0 4px;text-align:right}.voice-visualizer__progress-indicator{position:absolute;top:0;pointer-events:none;height:100%;width:1px;background-color:#efefef}.voice-visualizer__progress-indicator-time{position:absolute;top:3%;left:1px;width:fit-content;box-sizing:border-box;min-width:41px;margin:0;padding:0 7px;font-size:12px;border-radius:0 4px 4px 0;text-align:left;color:#000;font-weight:500;background-color:#efefef}.voice-visualizer__progress-indicator-time.voice-visualizer__progress-indicator-time-left{left:unset;right:1px;border-radius:4px 0 0 4px;text-align:right}.voice-visualizer__audio-info-container{box-sizing:border-box;height:55px;display:flex;align-items:center;justify-content:center;gap:30px}.voice-visualizer__audio-info-time{margin:15px 0;min-width:38px;text-align:left}.voice-visualizer__visually-hidden{position:absolute;width:1px;height:1px;margin:-1px;padding:0;border:4px solid #c5c5c5;white-space:nowrap;clip-path:inset(100%);clip:rect(0 0 0 0);overflow:hidden}")})();
import { jsx as a, jsxs as ve, Fragment as Re } from "react/jsx-runtime";
import { useState as d, useRef as N, useCallback as Je, forwardRef as Qe, useEffect as F, useLayoutEffect as Ve } from "react";
import { jsx as s, jsxs as ve, Fragment as Re } from "react/jsx-runtime";
import { useState as l, useRef as S, useCallback as Ve, forwardRef as qe, useEffect as F, useLayoutEffect as Xe } from "react";
const Ee = ({

@@ -17,6 +17,6 @@ canvas: e,

w: o,
h: l
h: m
}) => {
e.fillStyle = r, e.beginPath(), e.roundRect ? (e.roundRect(t, c, o, l, n), e.fill()) : e.fillRect(t, c, o, l);
}, qe = ({
e.fillStyle = r, e.beginPath(), e.roundRect ? (e.roundRect(t, c, o, m, n), e.fill()) : e.fillRect(t, c, o, m);
}, Ke = ({
barsData: e,

@@ -28,6 +28,6 @@ canvas: r,

mainBarColor: o,
secondaryBarColor: l,
secondaryBarColor: m,
currentAudioTime: f = 0,
rounded: A,
duration: s
rounded: w,
duration: a
}) => {

@@ -37,9 +37,9 @@ const M = Ee({ canvas: r, backgroundColor: c });

return;
const { context: g, height: p } = M, I = f / s;
const { context: g, height: p } = M, I = f / a;
e.forEach((u, L) => {
const R = L / e.length, h = I > R;
const O = L / e.length, h = I > O;
Ae({
context: g,
color: h ? l : o,
rounded: A,
color: h ? m : o,
rounded: w,
x: L * (n + t * n),

@@ -52,3 +52,3 @@ y: p / 2 - u.max,

};
function Xe({
function et({
context: e,

@@ -71,3 +71,3 @@ color: r,

}
const Ke = ({
const tt = ({
audioData: e,

@@ -79,6 +79,6 @@ unit: r,

isRecordingInProgress: o,
isPausedRecording: l,
isPausedRecording: m,
picks: f,
backgroundColor: A,
barWidth: s,
backgroundColor: w,
barWidth: a,
mainBarColor: M,

@@ -90,50 +90,50 @@ secondaryBarColor: g,

}) => {
const L = Ee({ canvas: c, backgroundColor: A });
const L = Ee({ canvas: c, backgroundColor: w });
if (!L)
return;
const { context: R, height: h, width: H, halfWidth: j } = L;
const { context: O, height: h, width: $, halfWidth: A } = L;
if (e != null && e.length && o) {
const Z = Math.max(...e);
if (!l) {
if (t.current >= s) {
const U = Math.max(...e);
if (!m) {
if (t.current >= a) {
t.current = 0;
const b = (h - Z / 258 * h) / h * 100, U = (-h + Z / 258 * h * 2) / h * 100, $ = n.current === s ? {
startY: b,
barHeight: U
const E = (h - U / 258 * h) / h * 100, Y = (-h + U / 258 * h * 2) / h * 100, R = n.current === a ? {
startY: E,
barHeight: Y
} : null;
n.current >= r ? n.current = s : n.current += s, f.length > (u ? H : j) / s && f.pop(), f.unshift($);
n.current >= r ? n.current = a : n.current += a, f.length > (u ? $ : A) / a && f.pop(), f.unshift(R);
}
t.current += 1;
}
!u && J(), I && Ae({
context: R,
!u && Q(), I && Ae({
context: O,
rounded: p,
color: M,
x: u ? H : j,
y: h - Z / 258 * h,
h: -h + Z / 258 * h * 2,
w: s
x: u ? $ : A,
y: h - U / 258 * h,
h: -h + U / 258 * h * 2,
w: a
});
let k = (u ? H : j) - t.current;
f.forEach((b) => {
b && Ae({
context: R,
let W = (u ? $ : A) - t.current;
f.forEach((E) => {
E && Ae({
context: O,
color: M,
rounded: p,
x: k,
y: b.startY * h / 100 > h / 2 - 1 ? h / 2 - 1 : b.startY * h / 100,
h: b.barHeight * h / 100 > 2 ? b.barHeight * h / 100 : 2,
w: s
}), k -= s;
x: W,
y: E.startY * h / 100 > h / 2 - 1 ? h / 2 - 1 : E.startY * h / 100,
h: E.barHeight * h / 100 > 2 ? E.barHeight * h / 100 : 2,
w: a
}), W -= a;
});
} else
f.length = 0;
function J() {
Xe({
context: R,
function Q() {
et({
context: O,
color: g,
rounded: p,
width: H,
width: $,
height: h,
barWidth: s
barWidth: a
});

@@ -155,3 +155,3 @@ }

).charAt(0)}`;
}, et = (e) => {
}, rt = (e) => {
const r = Math.floor(e / 1e3), n = Math.floor(r / 3600), t = Math.floor(r % 3600 / 60), c = r % 60;

@@ -171,3 +171,3 @@ return n > 0 ? `${String(n).padStart(2, "0")}:${String(t).padStart(

}
const tt = ({
const nt = ({
bufferData: e,

@@ -179,22 +179,22 @@ height: r,

}) => {
const o = n / (t + c * t), l = Math.floor(e.length / o), f = r / 2;
let A = [], s = 0;
const o = n / (t + c * t), m = Math.floor(e.length / o), f = r / 2;
let w = [], a = 0;
for (let M = 0; M < o; M++) {
const g = [];
let p = 0;
for (let u = 0; u < l && M * l + u < e.length; u++) {
const L = e[M * l + u];
for (let u = 0; u < m && M * m + u < e.length; u++) {
const L = e[M * m + u];
L > 0 && (g.push(L), p++);
}
const I = g.reduce((u, L) => u + L, 0) / p;
I > s && (s = I), A.push({ max: I });
I > a && (a = I), w.push({ max: I });
}
if (f * 0.95 > s * f) {
const M = f * 0.95 / s;
A = A.map((g) => ({
if (f * 0.95 > a * f) {
const M = f * 0.95 / a;
w = w.map((g) => ({
max: g.max > 0.01 ? g.max * M : 1
}));
}
return A;
}, rt = (e) => {
return w;
}, it = (e) => {
if (!e)

@@ -204,3 +204,3 @@ return "";

return r && r.length >= 2 ? `.${r[1]}` : "";
}, nt = (e) => {
}, ct = (e) => {
const r = Math.floor(e / 3600), n = Math.floor(e % 3600 / 60), t = e % 60, c = Math.floor(

@@ -217,3 +217,3 @@ (t - Math.floor(t)) * 1e3

).charAt(0)}${String(c).charAt(1)}s`;
}, it = (e) => {
}, ot = (e) => {
onmessage = (r) => {

@@ -223,4 +223,4 @@ postMessage(e(r.data));

};
function ct(e, r) {
const [n, t] = d(r);
function st(e, r) {
const [n, t] = l(r);
return {

@@ -230,17 +230,17 @@ result: n,

run: (o) => {
const l = new Worker(
const m = new Worker(
// eslint-disable-next-line @typescript-eslint/restrict-template-expressions
URL.createObjectURL(new Blob([`(${it})(${e})`]))
URL.createObjectURL(new Blob([`(${ot})(${e})`]))
);
l.onmessage = (f) => {
f.data && (t(f.data), l.terminate());
}, l.onerror = (f) => {
console.error(f.message), l.terminate();
}, l.postMessage(o);
m.onmessage = (f) => {
f.data && (t(f.data), m.terminate());
}, m.onerror = (f) => {
console.error(f.message), m.terminate();
}, m.postMessage(o);
}
};
}
const ot = (e, r = 250) => {
const n = N();
return Je(
const at = (e, r = 250) => {
const n = S();
return Ve(
// eslint-disable-next-line @typescript-eslint/no-explicit-any

@@ -256,7 +256,7 @@ (...t) => {

};
const at = ({
const ut = ({
color: e = "#000000",
stroke: r = 2,
className: n
}) => /* @__PURE__ */ a(
}) => /* @__PURE__ */ s(
"svg",

@@ -268,3 +268,3 @@ {

className: n,
children: /* @__PURE__ */ a(
children: /* @__PURE__ */ s(
"path",

@@ -283,3 +283,3 @@ {

reflect: r
}) => /* @__PURE__ */ a(
}) => /* @__PURE__ */ s(
"svg",

@@ -290,3 +290,3 @@ {

className: `voice-visualizer__canvas-audio-wave-icon ${r ? "voice-visualizer__canvas-audio-wave-icon2" : ""}`,
children: /* @__PURE__ */ a(
children: /* @__PURE__ */ s(
"path",

@@ -299,3 +299,3 @@ {

}
), Fe = "", st = "", Ue = "", ut = "", mt = Qe(
), Fe = "", ht = "", Ue = "", lt = "", dt = qe(
({

@@ -309,6 +309,6 @@ controls: {

currentAudioTime: o,
bufferFromRecordedBlob: l,
bufferFromRecordedBlob: m,
togglePauseResume: f,
startRecording: A,
stopRecording: s,
startRecording: w,
stopRecording: a,
saveAudioFile: M,

@@ -320,36 +320,36 @@ isAvailableRecordedAudio: g,

isCleared: L,
formattedDuration: R,
formattedDuration: O,
formattedRecordingTime: h,
formattedRecordedAudioCurrentTime: H,
clearCanvas: j,
setCurrentAudioTime: J,
_setIsProcessingRecordedAudio: Z
formattedRecordedAudioCurrentTime: $,
clearCanvas: A,
setCurrentAudioTime: Q,
_setIsProcessingRecordedAudio: U
},
width: k = "100%",
height: b = 200,
speed: U = 3,
backgroundColor: $ = "transparent",
mainBarColor: E = "#FFFFFF",
secondaryBarColor: Q = "#5e5e5e",
barWidth: te = 2,
gap: V = 1,
rounded: q = 5,
width: W = "100%",
height: E = 200,
speed: Y = 3,
backgroundColor: R = "transparent",
mainBarColor: _ = "#FFFFFF",
secondaryBarColor: V = "#5e5e5e",
barWidth: re = 2,
gap: q = 1,
rounded: X = 5,
isControlPanelShown: ye = !0,
isDownloadAudioButtonShown: re = !1,
animateCurrentPick: ne = !0,
fullscreen: X = !1,
onlyRecording: W = !1,
isDefaultUIShown: ie = !0,
defaultMicrophoneIconColor: de = E,
defaultAudioWaveIconColor: Le = E,
isDownloadAudioButtonShown: ne = !1,
animateCurrentPick: ie = !0,
fullscreen: K = !1,
onlyRecording: J = !1,
isDefaultUIShown: ce = !0,
defaultMicrophoneIconColor: de = _,
defaultAudioWaveIconColor: Le = _,
mainContainerClassName: fe,
canvasContainerClassName: Y,
isProgressIndicatorShown: z = !W,
progressIndicatorClassName: _,
isProgressIndicatorTimeShown: K = !0,
progressIndicatorTimeClassName: ce,
isProgressIndicatorOnHoverShown: G = !W,
progressIndicatorOnHoverClassName: D,
isProgressIndicatorTimeOnHoverShown: C = !0,
progressIndicatorTimeOnHoverClassName: m,
canvasContainerClassName: G,
isProgressIndicatorShown: z = !J,
progressIndicatorClassName: C,
isProgressIndicatorTimeShown: ee = !0,
progressIndicatorTimeClassName: oe,
isProgressIndicatorOnHoverShown: B = !J,
progressIndicatorOnHoverClassName: y,
isProgressIndicatorTimeOnHoverShown: x = !0,
progressIndicatorTimeOnHoverClassName: v,
isAudioProcessingTextShown: pe = !0,

@@ -359,55 +359,55 @@ audioProcessingTextClassName: je,

}, we) => {
const [oe, De] = d(0), [x, ae] = d(0), [se, Te] = d(0), [ze, ue] = d(0), [he, Ne] = d(!1), [le, be] = d(0), i = le < 768, y = Math.trunc(U), S = Math.trunc(V), w = Math.trunc(
i && S > 0 ? te + 1 : te
), v = N(null), ee = N([]), B = N(y), me = N(w), O = N(w), ge = N(null), {
const [se, De] = l(0), [H, ae] = l(0), [ue, Te] = l(0), [ze, he] = l(0), [le, Ne] = l(!1), [me, be] = l(0), [i, j] = l(!1), N = me < 768, Z = Math.trunc(Y), P = Math.trunc(q), D = Math.trunc(
N && P > 0 ? re + 1 : re
), d = S(null), te = S([]), T = S(Z), Ge = S(D), Be = S(D), ge = S(null), {
result: Me,
setResult: Ge,
run: Be
} = ct(tt, []), _e = ot(ke), Pe = w + S * w;
setResult: Pe,
run: ke
} = st(nt, []), _e = at(Je), We = D + P * D;
F(() => {
_e();
const T = () => {
Z(!0), _e();
const b = () => {
g && j(!0), _e();
};
return window.addEventListener("resize", T), () => {
window.removeEventListener("resize", T);
return window.addEventListener("resize", b), () => {
window.removeEventListener("resize", b);
};
}, [k, g]), Ve(() => {
v.current && ((B.current >= y || !e.length) && (B.current = 0, Ke({
}, [W, g]), Xe(() => {
d.current && ((T.current >= Z || !e.length) && (T.current = 0, tt({
audioData: e,
unit: Pe,
index: me,
index2: O,
canvas: v.current,
picks: ee.current,
unit: We,
index: Ge,
index2: Be,
canvas: d.current,
picks: te.current,
isRecordingInProgress: r,
isPausedRecording: I,
backgroundColor: $,
mainBarColor: E,
secondaryBarColor: Q,
barWidth: w,
rounded: q,
animateCurrentPick: ne,
fullscreen: X
})), B.current += 1);
backgroundColor: R,
mainBarColor: _,
secondaryBarColor: V,
barWidth: D,
rounded: X,
animateCurrentPick: ie,
fullscreen: K
})), T.current += 1);
}, [
v.current,
d.current,
e,
w,
$,
E,
Q,
q,
D,
R,
_,
V,
X,
ie,
K,
ce,
ze
]), F(() => {
var T, P;
var b, k;
if (g)
return he ? (T = v.current) == null || T.addEventListener("mouseleave", xe) : (P = v.current) == null || P.addEventListener("mouseenter", Ce), () => {
return le ? (b = d.current) == null || b.addEventListener("mouseleave", xe) : (k = d.current) == null || k.addEventListener("mouseenter", Ce), () => {
var Ie, $e;
he ? (Ie = v.current) == null || Ie.removeEventListener(
le ? (Ie = d.current) == null || Ie.removeEventListener(
"mouseleave",
xe
) : ($e = v.current) == null || $e.removeEventListener(
) : ($e = d.current) == null || $e.removeEventListener(
"mouseenter",

@@ -417,19 +417,19 @@ Ce

};
}, [he, g]), F(() => {
var P;
if (!l || !v.current || r)
}, [le, g]), F(() => {
var k;
if (!m || !d.current || r)
return;
if (W) {
j();
if (J) {
A();
return;
}
ee.current = [];
const T = l.getChannelData(0);
return Be({
bufferData: T,
height: se,
te.current = [];
const b = m.getChannelData(0);
return ke({
bufferData: b,
height: ue,
width: ze,
barWidth: w,
gap: S
}), (P = v.current) == null || P.addEventListener(
barWidth: D,
gap: P
}), (k = d.current) == null || k.addEventListener(
"mousemove",

@@ -439,3 +439,3 @@ He

var Ie;
(Ie = v.current) == null || Ie.removeEventListener(
(Ie = d.current) == null || Ie.removeEventListener(
"mousemove",

@@ -446,25 +446,25 @@ He

}, [
l,
x,
se,
V,
te
m,
H,
ue,
q,
re
]), F(() => {
if (!(W || !(Me != null && Me.length) || !v.current)) {
if (!(J || !(Me != null && Me.length) || !d.current)) {
if (L) {
Ge([]);
Pe([]);
return;
}
qe({
Ke({
barsData: Me,
canvas: v.current,
barWidth: w,
gap: S,
backgroundColor: $,
mainBarColor: E,
secondaryBarColor: Q,
canvas: d.current,
barWidth: D,
gap: P,
backgroundColor: R,
mainBarColor: _,
secondaryBarColor: V,
currentAudioTime: o,
rounded: q,
rounded: X,
duration: t
}), Z(!1);
}), j(!1), U(!1);
}

@@ -475,20 +475,20 @@ }, [

L,
q,
$,
E,
Q
X,
R,
_,
V
]), F(() => {
u && v.current && Ee({
canvas: v.current,
backgroundColor: $
(u || i) && d.current && Ee({
canvas: d.current,
backgroundColor: R
});
}, [u]);
function ke() {
if (!ge.current || !v.current)
}, [u, i]);
function Je() {
if (!ge.current || !d.current)
return;
B.current = y;
const T = Math.trunc(
T.current = Z;
const b = Math.trunc(
ge.current.clientHeight * window.devicePixelRatio / 2
) * 2;
ae(ge.current.clientWidth), Te(T), ue(
ae(ge.current.clientWidth), Te(b), he(
Math.round(

@@ -503,7 +503,7 @@ ge.current.clientWidth * window.devicePixelRatio

Ne(!1);
}, He = (T) => {
De(T.offsetX);
}, We = (T) => {
const P = we;
P.current && v.current && (P.current.currentTime = t / x * (T.clientX - v.current.getBoundingClientRect().left), J(P.current.currentTime));
}, He = (b) => {
De(b.offsetX);
}, Qe = (b) => {
const k = we;
k.current && d.current && (k.current.currentTime = t / H * (b.clientX - d.current.getBoundingClientRect().left), Q(k.current.currentTime));
};

@@ -514,16 +514,16 @@ return /* @__PURE__ */ ve("div", { className: `voice-visualizer ${fe ?? ""}`, children: [

{
className: `voice-visualizer__canvas-container ${Y ?? ""}`,
className: `voice-visualizer__canvas-container ${G ?? ""}`,
ref: ge,
style: { width: Ze(k) },
style: { width: Ze(W) },
children: [
/* @__PURE__ */ a(
/* @__PURE__ */ s(
"canvas",
{
ref: v,
ref: d,
width: ze,
height: se,
onClick: We,
height: ue,
onClick: Qe,
style: {
height: Ze(b),
width: x
height: Ze(E),
width: H
},

@@ -533,12 +533,12 @@ children: "Your browser does not support HTML5 Canvas."

),
ie && L && /* @__PURE__ */ ve(Re, { children: [
/* @__PURE__ */ a(Oe, { color: Le }),
/* @__PURE__ */ a(Oe, { color: Le, reflect: !0 }),
/* @__PURE__ */ a(
ce && L && /* @__PURE__ */ ve(Re, { children: [
/* @__PURE__ */ s(Oe, { color: Le }),
/* @__PURE__ */ s(Oe, { color: Le, reflect: !0 }),
/* @__PURE__ */ s(
"button",
{
onClick: A,
onClick: w,
className: "voice-visualizer__canvas-microphone-btn",
children: /* @__PURE__ */ a(
at,
children: /* @__PURE__ */ s(
ut,
{

@@ -553,25 +553,25 @@ color: de,

] }),
pe && u && /* @__PURE__ */ a(
pe && (u || i) && /* @__PURE__ */ s(
"p",
{
className: `voice-visualizer__canvas-audio-processing ${je ?? ""}`,
style: { color: E },
style: { color: _ },
children: "Processing Audio..."
}
),
he && g && !i && G && /* @__PURE__ */ a(
le && g && !i && !N && B && /* @__PURE__ */ s(
"div",
{
className: `voice-visualizer__progress-indicator-hovered ${D ?? ""}`,
className: `voice-visualizer__progress-indicator-hovered ${y ?? ""}`,
style: {
left: oe
left: se
},
children: C && /* @__PURE__ */ a(
children: x && /* @__PURE__ */ s(
"p",
{
className: `voice-visualizer__progress-indicator-hovered-time
${x - oe < 70 ? "voice-visualizer__progress-indicator-hovered-time-left" : ""}
${m ?? ""}`,
${H - se < 70 ? "voice-visualizer__progress-indicator-hovered-time-left" : ""}
${v ?? ""}`,
children: Ye(
t / x * oe
t / H * se
)

@@ -582,14 +582,14 @@ }

),
z && g && t ? /* @__PURE__ */ a(
z && g && !i && t ? /* @__PURE__ */ s(
"div",
{
className: `voice-visualizer__progress-indicator ${_ ?? ""}`,
className: `voice-visualizer__progress-indicator ${C ?? ""}`,
style: {
left: o / t * x
left: o / t * H
},
children: K && /* @__PURE__ */ a(
children: ee && /* @__PURE__ */ s(
"p",
{
className: `voice-visualizer__progress-indicator-time ${x - o * x / t < 70 ? "voice-visualizer__progress-indicator-time-left" : ""} ${ce ?? ""}`,
children: H
className: `voice-visualizer__progress-indicator-time ${H - o * H / t < 70 ? "voice-visualizer__progress-indicator-time-left" : ""} ${oe ?? ""}`,
children: $
}

@@ -604,7 +604,7 @@ )

/* @__PURE__ */ ve("div", { className: "voice-visualizer__audio-info-container", children: [
r && /* @__PURE__ */ a("p", { className: "voice-visualizer__audio-info-time", children: h }),
t && !u ? /* @__PURE__ */ a("p", { children: R }) : null
r && /* @__PURE__ */ s("p", { className: "voice-visualizer__audio-info-time", children: h }),
t && !u ? /* @__PURE__ */ s("p", { children: O }) : null
] }),
/* @__PURE__ */ ve("div", { className: "voice-visualizer__buttons-container", children: [
r && /* @__PURE__ */ a(
r && /* @__PURE__ */ s(
"button",

@@ -614,3 +614,3 @@ {

onClick: f,
children: /* @__PURE__ */ a(
children: /* @__PURE__ */ s(
"img",

@@ -624,3 +624,3 @@ {

),
!L && /* @__PURE__ */ a(
!L && /* @__PURE__ */ s(
"button",

@@ -630,7 +630,7 @@ {

onClick: f,
disabled: u,
children: /* @__PURE__ */ a(
disabled: u || i,
children: /* @__PURE__ */ s(
"img",
{
src: p ? st : Ue,
src: p ? ht : Ue,
alt: p ? "Play" : "Pause"

@@ -641,28 +641,28 @@ }

),
L && /* @__PURE__ */ a(
L && /* @__PURE__ */ s(
"button",
{
className: "voice-visualizer__btn-center",
onClick: A,
children: /* @__PURE__ */ a("img", { src: Fe, alt: "Microphone" })
onClick: w,
children: /* @__PURE__ */ s("img", { src: Fe, alt: "Microphone" })
}
),
/* @__PURE__ */ a(
/* @__PURE__ */ s(
"button",
{
className: `voice-visualizer__btn-center voice-visualizer__btn-center-pause ${r ? "" : "voice-visualizer__visually-hidden"}`,
onClick: s,
children: /* @__PURE__ */ a("img", { src: ut, alt: "Stop" })
onClick: a,
children: /* @__PURE__ */ s("img", { src: lt, alt: "Stop" })
}
),
!L && /* @__PURE__ */ a(
!L && /* @__PURE__ */ s(
"button",
{
onClick: j,
onClick: A,
className: `voice-visualizer__btn ${Se ?? ""}`,
disabled: u,
disabled: u || i,
children: "Clear"
}
),
re && n && /* @__PURE__ */ a(
ne && n && /* @__PURE__ */ s(
"button",

@@ -672,3 +672,3 @@ {

className: `voice-visualizer__btn ${Se ?? ""}`,
disabled: u,
disabled: u || i,
children: "Download Audio"

@@ -679,3 +679,3 @@ }

] }),
g && /* @__PURE__ */ a(
g && /* @__PURE__ */ s(
"audio",

@@ -692,3 +692,3 @@ {

);
function vt({
function ft({
onStartRecording: e,

@@ -700,126 +700,126 @@ onStopRecording: r,

onEndAudioPlayback: o,
onStartAudioPlayback: l,
onStartAudioPlayback: m,
onPausedAudioPlayback: f,
onResumedAudioPlayback: A
onResumedAudioPlayback: w
} = {}) {
const [s, M] = d(!1), [g, p] = d(!1), [I, u] = d(null), [L, R] = d(new Uint8Array(0)), [h, H] = d(!1), [j, J] = d(null), [Z, k] = d(null), [b, U] = d(0), [$, E] = d(0), [Q, te] = d(0), [V, q] = d(""), [ye, re] = d(!0), [ne, X] = d(0), [W, ie] = d(!0), [de, Le] = d(!1), [fe, Y] = d(null), z = N(null), _ = N(null), K = N(null), ce = N(null), G = N(null), D = N(null), C = N(null), m = N(null), pe = !!(Z && !h), je = nt(Q), Se = et(b), we = Ye(ne);
const [a, M] = l(!1), [g, p] = l(!1), [I, u] = l(null), [L, O] = l(new Uint8Array(0)), [h, $] = l(!1), [A, Q] = l(null), [U, W] = l(null), [E, Y] = l(0), [R, _] = l(0), [V, re] = l(0), [q, X] = l(""), [ye, ne] = l(!0), [ie, K] = l(0), [J, ce] = l(!0), [de, Le] = l(!1), [fe, G] = l(null), z = S(null), C = S(null), ee = S(null), oe = S(null), B = S(null), y = S(null), x = S(null), v = S(null), pe = !!(U && !h), je = ct(V), Se = rt(E), we = Ye(ie);
F(() => {
if (!s || g)
if (!a || g)
return;
const y = setInterval(() => {
const S = performance.now();
U((w) => w + (S - $)), E(S);
const j = setInterval(() => {
const N = performance.now();
Y((Z) => Z + (N - R)), _(N);
}, 1e3);
return () => clearInterval(y);
}, [$, g, s]), F(() => {
if (!j || j.size === 0)
return () => clearInterval(j);
}, [R, g, a]), F(() => {
if (!A || A.size === 0)
return;
(async () => {
var y;
var j;
try {
Y(null);
const S = new Blob([j], {
type: (y = z.current) == null ? void 0 : y.mimeType
}), w = URL.createObjectURL(S);
w && q(w);
const v = await j.arrayBuffer(), ee = new AudioContext(), B = (O) => {
k(O), te(O.duration - 0.06);
}, me = (O) => {
Y(O);
G(null);
const N = new Blob([A], {
type: (j = z.current) == null ? void 0 : j.mimeType
}), Z = URL.createObjectURL(N);
Z && X(Z);
const P = await A.arrayBuffer(), D = new AudioContext(), d = (T) => {
W(T), re(T.duration - 0.06);
}, te = (T) => {
G(T);
};
ee.decodeAudioData(
v,
B,
me
D.decodeAudioData(
P,
d,
te
);
} catch (S) {
if (console.error("Error processing the audio blob:", S), S instanceof Error) {
Y(S);
} catch (N) {
if (console.error("Error processing the audio blob:", N), N instanceof Error) {
G(N);
return;
}
Y(new Error("Error processing the audio blob"));
G(new Error("Error processing the audio blob"));
}
})();
}, [j]), F(() => {
}, [A]), F(() => {
if (fe) {
ue();
he();
return;
}
}, [fe]), F(() => () => {
C.current && cancelAnimationFrame(C.current), G.current && G.current.disconnect(), _.current && _.current.state !== "closed" && _.current.close(), D.current && cancelAnimationFrame(D.current), m != null && m.current && m.current.removeEventListener("ended", le), z.current && z.current.removeEventListener(
x.current && cancelAnimationFrame(x.current), B.current && B.current.disconnect(), C.current && C.current.state !== "closed" && C.current.close(), y.current && cancelAnimationFrame(y.current), v != null && v.current && v.current.removeEventListener("ended", me), z.current && z.current.removeEventListener(
"dataavailable",
ae
);
}, []), F(() => (!W && !de && window.addEventListener("beforeunload", oe), () => {
window.removeEventListener("beforeunload", oe);
}), [W, de]);
const oe = (i) => {
}, []), F(() => (!J && !de && window.addEventListener("beforeunload", se), () => {
window.removeEventListener("beforeunload", se);
}), [J, de]);
const se = (i) => {
i.preventDefault(), i.returnValue = "";
}, De = () => {
navigator.mediaDevices.getUserMedia({ audio: !0 }).then((i) => {
ue(), ie(!1), E(performance.now()), M(!0), u(i), _.current = new window.AudioContext(), K.current = _.current.createAnalyser(), ce.current = new Uint8Array(
K.current.frequencyBinCount
), G.current = _.current.createMediaStreamSource(i), G.current.connect(K.current), z.current = new MediaRecorder(i), z.current.addEventListener(
he(), ce(!1), _(performance.now()), M(!0), u(i), C.current = new window.AudioContext(), ee.current = C.current.createAnalyser(), oe.current = new Uint8Array(
ee.current.frequencyBinCount
), B.current = C.current.createMediaStreamSource(i), B.current.connect(ee.current), z.current = new MediaRecorder(i), z.current.addEventListener(
"dataavailable",
ae
), z.current.start(), x();
), z.current.start(), H();
}).catch((i) => {
if (console.error("Error starting audio recording:", i), i instanceof Error) {
Y(i);
G(i);
return;
}
Y(new Error("Error starting audio recording"));
G(new Error("Error starting audio recording"));
});
}, x = () => {
K.current.getByteTimeDomainData(ce.current), R(new Uint8Array(ce.current)), D.current = requestAnimationFrame(x);
}, H = () => {
ee.current.getByteTimeDomainData(oe.current), O(new Uint8Array(oe.current)), y.current = requestAnimationFrame(H);
}, ae = (i) => {
z.current && J(i.data);
}, se = () => {
C.current && cancelAnimationFrame(C.current), m.current && (X(m.current.currentTime), C.current = requestAnimationFrame(se));
z.current && Q(i.data);
}, ue = () => {
x.current && cancelAnimationFrame(x.current), v.current && (K(v.current.currentTime), x.current = requestAnimationFrame(ue));
}, Te = () => {
s || (e && e(), De());
a || (e && e(), De());
}, ze = () => {
s && (r && r(), H(!0), M(!1), U(0), p(!1), D.current && cancelAnimationFrame(D.current), G.current && G.current.disconnect(), _.current && _.current.state !== "closed" && _.current.close(), I == null || I.getTracks().forEach((i) => i.stop()), z.current && (z.current.stop(), z.current.removeEventListener(
a && (r && r(), $(!0), M(!1), Y(0), p(!1), y.current && cancelAnimationFrame(y.current), B.current && B.current.disconnect(), C.current && C.current.state !== "closed" && C.current.close(), I == null || I.getTracks().forEach((i) => i.stop()), z.current && (z.current.stop(), z.current.removeEventListener(
"dataavailable",
ae
)));
}, ue = () => {
D.current && cancelAnimationFrame(D.current), m != null && m.current && m.current.removeEventListener("ended", le), C.current && cancelAnimationFrame(C.current), z.current && (z.current.removeEventListener(
}, he = () => {
y.current && cancelAnimationFrame(y.current), v != null && v.current && v.current.removeEventListener("ended", me), x.current && cancelAnimationFrame(x.current), z.current && (z.current.removeEventListener(
"dataavailable",
ae
), z.current.stop(), z.current = null), I == null || I.getTracks().forEach((i) => i.stop()), z.current = null, _.current = null, K.current = null, ce.current = null, G.current = null, D.current = null, C.current = null, c && c(), u(null), M(!1), H(!1), J(null), k(null), U(0), E(0), te(0), q(""), X(0), re(!0), p(!1), R(new Uint8Array(0)), Y(null), ie(!0);
}, he = (i) => {
i instanceof Blob && (ue(), Le(!0), ie(!1), H(!0), M(!1), U(0), p(!1), J(i));
), z.current.stop(), z.current = null), I == null || I.getTracks().forEach((i) => i.stop()), z.current = null, C.current = null, ee.current = null, oe.current = null, B.current = null, y.current = null, x.current = null, c && c(), u(null), M(!1), $(!1), Q(null), W(null), Y(0), _(0), re(0), X(""), K(0), ne(!0), p(!1), O(new Uint8Array(0)), G(null), ce(!0);
}, le = (i) => {
i instanceof Blob && (he(), Le(!0), ce(!1), $(!0), M(!1), Y(0), p(!1), Q(i));
}, Ne = () => {
var i, y, S, w, v, ee, B, me;
if (s) {
p((O) => !O), ((i = z.current) == null ? void 0 : i.state) === "recording" ? (n && n(), (y = z.current) == null || y.pause(), U((O) => O + (performance.now() - $)), D.current && cancelAnimationFrame(D.current)) : (t && t(), (S = z.current) == null || S.resume(), E(performance.now()), D.current = requestAnimationFrame(x));
var i, j, N, Z, P, D, d, te;
if (a) {
p((T) => !T), ((i = z.current) == null ? void 0 : i.state) === "recording" ? (n && n(), (j = z.current) == null || j.pause(), Y((T) => T + (performance.now() - R)), y.current && cancelAnimationFrame(y.current)) : (t && t(), (N = z.current) == null || N.resume(), _(performance.now()), y.current = requestAnimationFrame(H));
return;
}
m.current && pe && (C.current && cancelAnimationFrame(C.current), (w = m.current) != null && w.paused ? (l && ne === 0 && l(), A && ne !== 0 && A(), (v = m.current) == null || v.addEventListener("ended", le), (ee = m.current) == null || ee.play(), re(!1), se()) : (f && f(), (B = m.current) == null || B.removeEventListener("ended", le), (me = m.current) == null || me.pause(), re(!0)));
}, le = () => {
re(!0), o && o(), m != null && m.current && (m.current.currentTime = 0, X(0));
v.current && pe && (x.current && cancelAnimationFrame(x.current), (Z = v.current) != null && Z.paused ? (m && ie === 0 && m(), w && ie !== 0 && w(), (P = v.current) == null || P.addEventListener("ended", me), (D = v.current) == null || D.play(), ne(!1), ue()) : (f && f(), (d = v.current) == null || d.removeEventListener("ended", me), (te = v.current) == null || te.pause(), ne(!0)));
}, me = () => {
ne(!0), o && o(), v != null && v.current && (v.current.currentTime = 0, K(0));
}, be = () => {
var y;
if (!V)
var j;
if (!q)
return;
const i = document.createElement("a");
i.href = V, i.download = `recorded_audio${rt(
(y = z.current) == null ? void 0 : y.mimeType
)}`, document.body.appendChild(i), i.click(), document.body.removeChild(i), URL.revokeObjectURL(V);
i.href = q, i.download = `recorded_audio${it(
(j = z.current) == null ? void 0 : j.mimeType
)}`, document.body.appendChild(i), i.click(), document.body.removeChild(i), URL.revokeObjectURL(q);
};
return {
isRecordingInProgress: s,
isRecordingInProgress: a,
isPausedRecording: g,
audioData: L,
recordingTime: b,
recordingTime: E,
isProcessingRecordedAudio: h,
recordedBlob: j,
recordedBlob: A,
mediaRecorder: z.current,
duration: Q,
currentAudioTime: ne,
audioSrc: V,
duration: V,
currentAudioTime: ie,
audioSrc: q,
isPausedRecordedAudio: ye,
bufferFromRecordedBlob: Z,
isCleared: W,
bufferFromRecordedBlob: U,
isCleared: J,
isAvailableRecordedAudio: pe,

@@ -830,3 +830,3 @@ isPreloadedBlob: de,

formattedRecordedAudioCurrentTime: we,
setPreloadedAudioBlob: he,
setPreloadedAudioBlob: le,
startRecording: Te,

@@ -836,12 +836,12 @@ togglePauseResume: Ne,

saveAudioFile: be,
clearCanvas: ue,
setCurrentAudioTime: X,
clearCanvas: he,
setCurrentAudioTime: K,
error: fe,
_setIsProcessingRecordedAudio: H,
audioRef: m
_setIsProcessingRecordedAudio: $,
audioRef: v
};
}
export {
mt as VoiceVisualizer,
vt as useVoiceVisualizer
dt as VoiceVisualizer,
ft as useVoiceVisualizer
};
{
"name": "react-voice-visualizer",
"private": false,
"version": "1.3.1",
"version": "1.3.2",
"type": "module",

@@ -6,0 +6,0 @@ "author": "Yurii Zarytskyi",

Sorry, the diff of this file is not supported yet