From ff5f293e14aeb5bf6b28a68745465479f9c346fb Mon Sep 17 00:00:00 2001
From: codeAndie <114886583+codeAndie@users.noreply.github.com>
Date: Fri, 18 Oct 2024 11:40:32 -0400
Subject: [PATCH] ui changes, ux / flow updates
Made the buttons appear sequentially, added some random ui ideas
---
src/App.css | 106 +++++++++++++++++++++++++++++
src/App.js | 7 +-
src/AudioRecorder.js | 156 +++++++++++++++++++++++++++++--------------
3 files changed, 215 insertions(+), 54 deletions(-)
diff --git a/src/App.css b/src/App.css
index 59ad501..2f4566e 100644
--- a/src/App.css
+++ b/src/App.css
@@ -1,3 +1,42 @@
+@keyframes pulse {
+ 0% {
+ transform: scale(1);
+ }
+ 50% {
+ transform: scale(1.1);
+ }
+ 100% {
+ transform: scale(1);
+ }
+}
+
+@keyframes bounce {
+ 0%, 100% {
+ transform: translateY(0);
+ }
+ 50% {
+ transform: translateY(-30px);
+ }
+}
+
+@keyframes move {
+ 0% {
+ transform: translate(0, 0);
+ }
+ 25% {
+ transform: translate(100px, -100px);
+ }
+ 50% {
+ transform: translate(200px, 0);
+ }
+ 75% {
+ transform: translate(100px, 100px);
+ }
+ 100% {
+ transform: translate(0, 0);
+ }
+}
+
.App {
font-family: Arial, sans-serif;
text-align: center;
@@ -24,3 +63,70 @@ button:hover {
audio {
margin-top: 15px;
}
+
+.circle-button {
+ width: 200px; /* Adjust size as needed */
+ height: 200px; /* Adjust size as needed */
+ background-color: red; /* Red background color */
+ color: white; /* White text color */
+ border: none; /* Remove border */
+ border-radius: 50%; /* Make it circular */
+ font-size: 32px; /* Adjust font size as needed */
+ display: flex; /* Use flexbox for centering */
+ align-items: center; /* Center content vertically */
+ justify-content: center; /* Center content horizontally */
+ cursor: pointer; /* Pointer cursor on hover */
+ transition: background-color 0.3s; /* Smooth transition for hover effect */
+}
+
+.circle-button:hover {
+ background-color: darkred; /* Darker red on hover */
+}
+
+.center-screen {
+ display: flex;
+ justify-content: center;
+ align-items: center;
+ height: 50vh; /* Full viewport height */
+}
+
+.pulse {
+ animation: pulse 1s infinite; /* Apply the pulse animation */
+}
+
+.vertical-stack {
+ display: flex;
+ flex-direction: column;
+ align-items: center;
+ justify-content: center;
+ gap: 1rem; /* Adjust the gap between elements as needed */
+}
+
+.secret-container {
+ padding: 20px; /* Add padding inside the container */
+ border-radius: 15px; /* Rounded corners */
+ background-color: #f9f9f9; /* Light background color */
+ box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); /* Subtle shadow for depth */
+ border: 2px solid #e0e0e0; /* Light border */
+ position: relative; /* For positioning pseudo-elements */
+ overflow: hidden; /* Hide overflow for pseudo-elements */
+ animation: bounce 5s infinite, move 10s infinite; /* Apply bounce and move animations */
+}
+
+.secret-container::before,
+.secret-container::after {
+ content: '';
+ position: absolute;
+ width: 100%;
+ height: 100%;
+ top: 0;
+ left: 0;
+ background: linear-gradient(45deg, rgba(255, 0, 0, 0.1), rgba(0, 0, 255, 0.1));
+ mix-blend-mode: multiply;
+ pointer-events: none; /* Allow clicks to pass through */
+ z-index: 1; /* Ensure it's above the content */
+}
+
+.secret-container::after {
+ background: linear-gradient(-45deg, rgba(0, 255, 0, 0.1), rgba(255, 255, 0, 0.1));
+}
\ No newline at end of file
diff --git a/src/App.js b/src/App.js
index 0845402..b138209 100644
--- a/src/App.js
+++ b/src/App.js
@@ -1,10 +1,9 @@
-import React from 'react';
-import AudioRecorder from './AudioRecorder'; // Import the component
+import React from "react";
+import AudioRecorder from "./AudioRecorder"; // Import the component
function App() {
return (
-
-
Welcome to Audio Recorder App
+
{/* Render the AudioRecorder component */}
);
diff --git a/src/AudioRecorder.js b/src/AudioRecorder.js
index 2cc3975..fa3b830 100644
--- a/src/AudioRecorder.js
+++ b/src/AudioRecorder.js
@@ -1,25 +1,30 @@
import React, { useState, useRef } from "react";
import { Loader2, Mic, Send, PlayCircle, AlertCircle } from "lucide-react";
+import "./App.css"; // Ensure this line is present
const AudioRecorder = () => {
const [isRecording, setIsRecording] = useState(false);
+ const [recording, setRecording] = useState(null);
const [audioUrl, setAudioUrl] = useState(null);
const [isSubmitting, setIsSubmitting] = useState(false);
+ const [isSubmitted, setIsSubmitted] = useState(false);
const [isLoading, setIsLoading] = useState(false);
const [randomAudioUrl, setRandomAudioUrl] = useState(null);
const [error, setError] = useState(null);
const mediaRecorderRef = useRef(null);
const audioChunksRef = useRef([]);
+ const [showSecret, setShowSecret] = useState(false);
+ const [showAudio, setShowAudio] = useState(false);
const startRecording = async () => {
+ console.log("Recording started");
try {
const stream = await navigator.mediaDevices.getUserMedia({ audio: true });
mediaRecorderRef.current = new MediaRecorder(stream);
-
mediaRecorderRef.current.ondataavailable = (event) => {
if (event.data.size > 0) audioChunksRef.current.push(event.data);
};
-
+ console.log("audio good");
mediaRecorderRef.current.onstop = () => {
const audioBlob = new Blob(audioChunksRef.current, {
type: "audio/webm",
@@ -38,15 +43,17 @@ const AudioRecorder = () => {
};
const stopRecording = () => {
+ console.log("Recording stopped");
mediaRecorderRef.current?.stop();
setIsRecording(false);
+ setShowAudio(true);
};
-
const sendAudioToAzureFunction = async () => {
if (!audioUrl) return;
setIsSubmitting(true);
setError(null);
+ setShowAudio(false);
const formData = new FormData();
const audioBlob = await fetch(audioUrl).then((r) => r.blob());
formData.append("audio", audioBlob, "recording.webm");
@@ -71,12 +78,14 @@ const AudioRecorder = () => {
setError("Failed to upload audio");
} finally {
setIsSubmitting(false);
+ setIsSubmitted(true);
}
};
const getRandomAudio = async () => {
setIsLoading(true);
setError(null);
+ setShowSecret(true);
try {
const response = await fetch(
"https://labracadabra-confessional.azurewebsites.net/api/loadRandomAudioBlob?"
@@ -101,6 +110,34 @@ const AudioRecorder = () => {
}
};
+ const handleDelete = () => {
+ setRecording(null);
+ setIsSubmitted(false);
+ setShowSecret(false);
+ setShowAudio(false);
+ };
+
+ const handleRestart = () => {
+ setRecording(null);
+ setIsSubmitted(false);
+ setShowSecret(false);
+ setAudioUrl(null); // Clear the recorded audio
+ };
+
+ const handleSubmit = () => {
+ setIsSubmitting(true);
+ // Logic to submit the recording to the database
+ // Simulate a delay for submission
+ setTimeout(() => {
+ setIsSubmitting(false);
+ setIsSubmitted(true);
+ }, 2000);
+ };
+
+ console.log("audioUrl", audioUrl);
+ console.log("show audio: ", showAudio);
+ console.log("issubmitted: ", isSubmitted);
+
return (
@@ -108,52 +145,66 @@ const AudioRecorder = () => {
Hellium Confessional
-
-
-
-
- {audioUrl && (
-
-
Preview:
-
+ {!recording && !isSubmitted && !isSubmitting && !showAudio && (
+
+
+ )}
+
+ {audioUrl && showAudio && (
+
+
+
Your secret:
+
+
+
+ )} */}
+ {isSubmitting ? "Submitting..." : "Submit secret"}
+
+
)}
-
-
-
+ {isSubmitting && (
+
+ )}
+
+ {isSubmitted && !showAudio && !showSecret && (
+
+
Recording submitted successfully!
+
+
+ )}
{error && (
@@ -162,15 +213,20 @@ const AudioRecorder = () => {
)}
- {randomAudioUrl && !error && (
-
-
Random Recording:
-