hacky but functional panel shifting with alpha changes

This commit is contained in:
Seth Forsgren 2022-11-30 16:30:52 -08:00
parent a90deb0cf2
commit 12b8f48a82
4 changed files with 283 additions and 38 deletions

View File

@ -1,23 +1,114 @@
import { NextComponentType } from 'next' import { NextComponentType } from 'next'
import { PlayingState } from '../types'
interface PromptEntryProps { interface PromptEntryProps {
prompt: string prompt: string
index: number index: number
className: string className: string
playingState: PlayingState
} }
export default function PromptEntry({ export default function PromptEntry({
prompt, prompt,
index, index,
className, className,
playingState,
}: PromptEntryProps) { }: PromptEntryProps) {
const getPromptCopy = (prompt: string) => {
switch (playingState) {
case PlayingState.UNINITIALIZED:
switch (index) {
case 0:
return prompt
case 1:
return prompt
case 2:
return prompt
case 3:
if (prompt == " " || prompt == "") {
return "..."
}
else {
return prompt
}
case 4:
if (prompt == " " || prompt == "") {
return "UP NEXT: Anything you want"
}
else {
return "UP NEXT: " + prompt
}
default: {
console.log("UNHANDLED default")
return prompt
}
}
case PlayingState.SAME_PROMPT:
switch (index) {
case 0:
return prompt
case 1:
return prompt
case 2:
return prompt
case 3:
if (prompt == " " || prompt == "") {
return "..."
}
else {
return prompt
}
case 4:
if (prompt == " " || prompt == "") {
return "UP NEXT: Anything you want"
}
else {
return "UP NEXT: " + prompt
}
default: {
console.log("UNHANDLED default")
return prompt
}
}
case PlayingState.TRANSITION:
switch (index) {
case 0:
return prompt
case 1:
return prompt
case 2:
return prompt
case 3:
return prompt
case 4:
if (prompt == " " || prompt == "") {
return "..."
}
else {
return prompt
}
case 5:
if (prompt == " " || prompt == "") {
return "UP NEXT: Anything you want"
}
else {
return "UP NEXT: " + prompt
}
default: {
console.log("UNHANDLED default")
return prompt
}
}
}
}
return ( return (
<> <>
<p className={className}> <p className={className}>
{index + " " + prompt} {getPromptCopy(prompt)}
{/* {prompt == "" ? index == 5 ? "UP NEXT: Anything you want" + prompt : "..." : index == 5 ? "UP NEXT: " + prompt : prompt} */} </p>
</p> </>
</>
) )
} }

View File

@ -1,33 +1,30 @@
import PromptEntry from "./PromptEntry"; import PromptEntry from "./PromptEntry";
import { InferenceResult, PromptInput } from "../types"; import { AppState, PlayingState, InferenceResult, PromptInput } from "../types";
import { useRef } from "react"; import { useRef } from "react";
interface PromptPanelProps { interface PromptPanelProps {
prompts: PromptInput[]; prompts: PromptInput[];
inferenceResults: InferenceResult[]; inferenceResults: InferenceResult[];
nowPlayingResult: InferenceResult; nowPlayingResult: InferenceResult;
appState: AppState;
changePrompt: (prompt: string, index: number) => void; changePrompt: (prompt: string, index: number) => void;
} }
enum PlayingState {
UNINITIALIZED = "UNINITIALIZED",
SAME_PROMPT = "SAME_PROMPT",
TRANSITION = "TRANSITION",
}
export default function PromptPanel({ export default function PromptPanel({
prompts, prompts,
inferenceResults, inferenceResults,
nowPlayingResult, nowPlayingResult,
appState,
changePrompt, changePrompt,
}: PromptPanelProps) { }: PromptPanelProps) {
const inputPrompt = useRef(null); const inputPrompt = useRef(null);
var playingState: PlayingState
const getDisplayPrompts = () => { const getDisplayPrompts = () => {
var displayPrompts = []; var displayPrompts = [];
var playingState: PlayingState
if (nowPlayingResult == null) { if (nowPlayingResult == null) {
playingState = PlayingState.UNINITIALIZED playingState = PlayingState.UNINITIALIZED
} else if (nowPlayingResult.input.start.prompt == nowPlayingResult.input.end.prompt) { } else if (nowPlayingResult.input.start.prompt == nowPlayingResult.input.end.prompt) {
@ -53,7 +50,7 @@ export default function PromptPanel({
// add the most recent end prompts to the displayPrompts // add the most recent end prompts to the displayPrompts
lastPlayedResultsAlphaTransition.forEach((result) => { lastPlayedResultsAlphaTransition.forEach((result) => {
displayPrompts.push({ prompt: result.input.end.prompt}); displayPrompts.push({ prompt: result.input.end.prompt });
}); });
// Handle the case where there are less than 4 played results (i.e. the initial state) // Handle the case where there are less than 4 played results (i.e. the initial state)
@ -90,17 +87,68 @@ export default function PromptPanel({
return displayPrompts; return displayPrompts;
} }
const getPromptEntryClassName = (index: number) => {
switch (playingState) {
case PlayingState.UNINITIALIZED:
console.log("promptEntryClassNames_5_0")
return promptEntryClassNames_5_0[index];
case PlayingState.SAME_PROMPT:
if (appState != AppState.TRANSITION) {
console.log("promptEntryClassNames_5_0")
return promptEntryClassNames_5_0[index];
} else {
switch (nowPlayingResult.input.alpha) {
case 0:
console.log("promptEntryClassNames_5_0")
return promptEntryClassNames_5_0[index];
case 0.25:
console.log("UNHANDLED promptEntryClassNames_5_25") // this is never reached currently
case 0.5:
console.log("promptEntryClassNames_5_50")
return promptEntryClassNames_5_50[index];
case 0.75:
console.log("promptEntryClassNames_5_75")
return promptEntryClassNames_5_75[index];
case 1:
console.log("promptEntryClassNames_5_1")
return promptEntryClassNames_5_1[index];
}
}
case PlayingState.TRANSITION:
switch (nowPlayingResult.input.alpha) {
case 0:
console.log("UNHANDLED promptEntryClassNames_6_0") // this is never reached currently
case 0.25:
console.log("promptEntryClassNames_6_25")
return promptEntryClassNames_6_25[index];
case 0.5:
console.log("promptEntryClassNames_6_50")
return promptEntryClassNames_6_50[index];
case 0.75:
console.log("promptEntryClassNames_6_75")
return promptEntryClassNames_6_75[index];
case 1:
console.log("promptEntryClassNames_6_1")
return promptEntryClassNames_6_1[index];
}
default:
console.log("UNHANDLED playingState: " + playingState)
}
}
return ( return (
<> <>
<main className="w-2/3 min-h-screen"> <main className="w-2/3 min-h-screen">
<div className="pl-20"> <div className="pl-20">
<div className="h-[80vh] flex flex-col justify-around pt-[5vh] pr-5"> <div className="h-[80vh] flex flex-col justify-around pt-[10vh] pr-5">
{getDisplayPrompts().map((prompt, index) => ( {getDisplayPrompts().map((prompt, index) => (
<PromptEntry <PromptEntry
prompt={prompt.prompt + " " + prompt.transitionCounter} prompt={prompt.prompt + " "}
className={promptEntryClassNames[index]} className={getPromptEntryClassName(index)}
index={index} index={index}
key={index} key={index}
playingState={playingState}
/> />
))} ))}
</div> </div>
@ -132,20 +180,118 @@ export default function PromptPanel({
); );
} }
const promptEntryClassNames = { const promptEntryClassNameDict = {
0: "font-medium text-xl text-gray-200 text-opacity-80", 0: "font-extralight text-xs text-gray-500 text-opacity-20",
1: "font-medium text-xl text-gray-200 text-opacity-80", 1: "font-extralight text-xs text-gray-400 text-opacity-20",
2: "font-medium text-xl text-gray-200 text-opacity-80", 2: "font-extralight text-sm text-gray-300 text-opacity-30",
3: "font-medium text-xl text-gray-200 text-opacity-80", 3: "font-extralight text-sm text-gray-200 text-opacity-30",
4: "font-medium text-xl text-gray-200 text-opacity-80", 4: "font-light text-sm text-gray-200 text-opacity-40",
5: "font-medium text-xl text-gray-200 text-opacity-80", 5: "font-light text-base text-gray-200 text-opacity-40",
}; 6: "font-light text-base text-gray-100 text-opacity-50",
7: "font-light text-base text-gray-100 text-opacity-50", // starter for 0
// const promptEntryClassNames = { 8: "font-light text-base text-gray-100 text-opacity-50",
// 0: "font-light text-sm text-gray-400 text-opacity-40", 9: "font-light text-lg text-gray-100 text-opacity-50",
// 1: "font-normal text-m text-gray-300 text-opacity-60", 10: "font-light text-lg text-gray-100 text-opacity-60",
// 2: "font-medium text-xl text-gray-200 text-opacity-80", 11: "font-normal text-lg text-gray-100 text-opacity-60",
// 3: "font-bold text-5xl text-white", // This is the primary prompt 12: "font-normal text-xl text-gray-100 text-opacity-60",
// 4: "font-medium text-3xl text-gray-100 text-opacity-80", // This is prompt it is transitioning to 13: "font-normal text-xl text-gray-100 text-opacity-70",
// 5: "font-normal text-m text-gray-200 text-opacity-60", // This is the UP NEXT prompt 14: "font-normal text-xl text-gray-100 text-opacity-70",
// }; 15: "font-normal text-xl text-gray-100 text-opacity-70", // starter for 1
16: "font-medium text-2xl text-gray-100 text-opacity-80", // 0%
17: "font-medium text-3xl text-gray-100 text-opacity-90", // 25%
18: "font-semibold text-4xl text-white", // 50%
19: "font-bold text-4xl text-white", // 75%
20: "font-bold text-5xl text-white",
21: "font-bold text-5xl text-white",
22: "font-bold text-5xl text-white",
23: "font-bold text-5xl text-white", // starter for 2 "start"
24: "font-bold text-5xl text-white",
25: "font-bold text-4xl text-white", // 75%
26: "font-semibold text-4xl text-white", // 50%
27: "font-medium text-3xl text-gray-100 text-opacity-90", // 25%
28: "font-normal text-2xl text-gray-100 text-opacity-80",
29: "font-normal text-l text-gray-100 text-opacity-70",
30: "font-normal text-l text-gray-100 text-opacity-70",
31: "font-normal text-l text-gray-100 text-opacity-70", // starter for 3 "end"
32: "font-normal text-base text-gray-100 text-opacity-70",
33: "font-normal text-base text-gray-100 text-opacity-60",
34: "font-normal text-base text-gray-100 text-opacity-60",
35: "font-normal text-base text-gray-100 text-opacity-60", // starter for 4 when "staging"
36: "font-normal text-base text-gray-100 text-opacity-60", // starter for 4 and 5 "Up Next"
}
// ClassNames below
// Note that 6_0 and 5_25 are never reached in current stucture
const promptEntryClassNames_5_0 = {
0: promptEntryClassNameDict[7],
1: promptEntryClassNameDict[15],
2: promptEntryClassNameDict[23], // This is the start and end prompt
3: promptEntryClassNameDict[31], // This is the staged prompt
4: promptEntryClassNameDict[36], // This is the UP NEXT prompt
}
const promptEntryClassNames_5_50 = {
0: promptEntryClassNameDict[6],
1: promptEntryClassNameDict[14],
2: promptEntryClassNameDict[22],
3: promptEntryClassNameDict[30],
4: promptEntryClassNameDict[36],
}
const promptEntryClassNames_5_75 = {
0: promptEntryClassNameDict[5],
1: promptEntryClassNameDict[13],
2: promptEntryClassNameDict[21],
3: promptEntryClassNameDict[29],
4: promptEntryClassNameDict[36],
}
const promptEntryClassNames_5_1 = {
0: promptEntryClassNameDict[4],
1: promptEntryClassNameDict[12],
2: promptEntryClassNameDict[20],
3: promptEntryClassNameDict[28],
4: promptEntryClassNameDict[36],
}
const promptEntryClassNames_6_25 = {
0: promptEntryClassNameDict[3],
1: promptEntryClassNameDict[11],
2: promptEntryClassNameDict[19],
3: promptEntryClassNameDict[27],
4: promptEntryClassNameDict[35],
5: promptEntryClassNameDict[36],
}
const promptEntryClassNames_6_50 = {
0: promptEntryClassNameDict[2],
1: promptEntryClassNameDict[10],
2: promptEntryClassNameDict[18],
3: promptEntryClassNameDict[26],
4: promptEntryClassNameDict[34],
5: promptEntryClassNameDict[36],
}
const promptEntryClassNames_6_75 = {
0: promptEntryClassNameDict[1],
1: promptEntryClassNameDict[9],
2: promptEntryClassNameDict[17],
3: promptEntryClassNameDict[25],
4: promptEntryClassNameDict[33],
5: promptEntryClassNameDict[36],
}
const promptEntryClassNames_6_1 = {
0: promptEntryClassNameDict[0],
1: promptEntryClassNameDict[8],
2: promptEntryClassNameDict[16],
3: promptEntryClassNameDict[24],
4: promptEntryClassNameDict[32],
5: promptEntryClassNameDict[36],
}

View File

@ -220,6 +220,7 @@ export default function Home() {
prompts={promptInputs} prompts={promptInputs}
inferenceResults={inferenceResults} inferenceResults={inferenceResults}
nowPlayingResult={nowPlayingResult} nowPlayingResult={nowPlayingResult}
appState={appState}
changePrompt={(prompt: string, index: number) => { changePrompt={(prompt: string, index: number) => {
const newPromptInputs = [...promptInputs]; const newPromptInputs = [...promptInputs];
newPromptInputs[index].prompt = prompt; newPromptInputs[index].prompt = prompt;

View File

@ -36,9 +36,16 @@ export interface InferenceResult {
duration_s: number; duration_s: number;
} }
// High-level state of the interactive app // High-level state of the app's inference call
export enum AppState { export enum AppState {
UNINITIALIZED = "UNINITIALIZED", UNINITIALIZED = "UNINITIALIZED",
SAME_PROMPT = "SAME_PROMPT", SAME_PROMPT = "SAME_PROMPT",
TRANSITION = "TRANSITION", TRANSITION = "TRANSITION",
} }
// High-level state of the actively playing audio
export enum PlayingState {
UNINITIALIZED = "UNINITIALIZED",
SAME_PROMPT = "SAME_PROMPT",
TRANSITION = "TRANSITION",
}