mirror of
https://github.com/eliasstepanik/strudel-docker.git
synced 2026-01-11 21:58:31 +00:00
134 lines
4.3 KiB
JavaScript
134 lines
4.3 KiB
JavaScript
import { useState } from 'react';
|
|
import LiteYouTubeEmbed from 'react-lite-youtube-embed';
|
|
import 'react-lite-youtube-embed/dist/LiteYouTubeEmbed.css';
|
|
|
|
export function shuffleArray(array) {
|
|
array = [...array];
|
|
for (let i = array.length - 1; i > 0; i--) {
|
|
const j = Math.floor(Math.random() * (i + 1));
|
|
[array[i], array[j]] = [array[j], array[i]];
|
|
}
|
|
return array;
|
|
}
|
|
let _shuffled;
|
|
|
|
export function Showcase() {
|
|
const [videos, setVideos] = useState(_shuffled);
|
|
return (
|
|
<>
|
|
<div className="flex space-x-2">
|
|
<button className="bg-lineHighlight p-2 rounded-md" onClick={() => setVideos(shuffleArray(_videos))}>
|
|
<span>shuffle videos</span>
|
|
</button>
|
|
<button className="bg-lineHighlight p-2 rounded-md" onClick={() => setVideos(_videos)}>
|
|
<span>newest first</span>
|
|
</button>
|
|
</div>
|
|
{videos.map((video, i) => (
|
|
<div key={i}>
|
|
<h2>{video.title}</h2>
|
|
<LiteYouTubeEmbed {...video} />
|
|
{video.description && <p>{video.description}</p>}
|
|
</div>
|
|
))}
|
|
</>
|
|
);
|
|
}
|
|
|
|
let _videos = [
|
|
{ title: 'DJ_Dave - Array [Lil Data Edit]', id: 'KUujFuTcuKc' },
|
|
{ title: 'DJ_Dave - Bitrot [v10101a Edit]', id: 'z_cJMdBp67Q' },
|
|
{ title: 'you will not steve reich your way out of it', id: 'xpILnXcWyuo' },
|
|
{ title: 'dough dream #1 - strudel jam 12/03/23', id: 'p0J7XrT9JEs' },
|
|
{ title: 'eddyflux & superdirtspatz at the dough cathedral', id: 'GrkwKMQ7_Ys' },
|
|
// solstice 2023
|
|
{ title: 'Jade Rose @ solstice stream 2023', id: 'wg0vW5Ac7L0' },
|
|
{
|
|
title: 'eddyflux @ solstice stream 2023',
|
|
id: 'DX8E99kC7q0',
|
|
description:
|
|
'A from-scratch session, starting with sample loops, later transitioning to more electronic territory.',
|
|
},
|
|
{
|
|
title: 'CCC @ solstice stream 2023',
|
|
id: '3uLTIDQa_Lc',
|
|
params: 'start=24',
|
|
},
|
|
{ title: 'letSeaTstrudeL @ solstice stream 2023', id: 'fTiX6dVtdWQ' },
|
|
{ title: 'totalgee (Glen F) @ solstice stream 2023', id: 'IvI6uaE3nLU' },
|
|
//
|
|
/* { // not sure if this is copyrighted ...
|
|
title: 'Creative Coding @ Chalmers University of Technology, video by svt.se',
|
|
id: '4zgHeNpG4wU',
|
|
}, */
|
|
{ title: 'Switch Angel - Morrow', id: 'qiatPuJpxLs' },
|
|
{
|
|
title: 'Jade Rose - Into your spell',
|
|
id: 'lxQgBeLQBgk',
|
|
description:
|
|
'Jade Rose performing with various synths via MIDI, superdirt via OSC and the native strudel superdough engine + vocal parts!',
|
|
},
|
|
// algo afro futures
|
|
{
|
|
title: 'Emma Osman @ (Algo|Afro) Futures 2023',
|
|
id: 'zUoZvkZ3J7Q',
|
|
params: 'start=1278',
|
|
},
|
|
{
|
|
title: 'Zach B-B @ (Algo|Afro) Futures 2023',
|
|
id: 'zUoZvkZ3J7Q',
|
|
params: 'start=2547',
|
|
},
|
|
{
|
|
title: 'Jamal Lloyd Davis @ (Algo|Afro) Futures 2023',
|
|
id: 'zUoZvkZ3J7Q',
|
|
params: 'start=3883',
|
|
},
|
|
{
|
|
title: 'Jim Osman @ (Algo|Afro) Futures 2023',
|
|
id: 'zUoZvkZ3J7Q',
|
|
params: 'start=5155',
|
|
},
|
|
{
|
|
title: 'φ @ (Algo|Afro) Futures 2023',
|
|
id: 'zUoZvkZ3J7Q',
|
|
params: 'start=7809',
|
|
},
|
|
{
|
|
title: 'Tomilola Olumide @ (Algo|Afro) Futures 2023',
|
|
id: 'zUoZvkZ3J7Q',
|
|
params: 'start=9224',
|
|
},
|
|
{
|
|
title: 'Tyga Blue @ (Algo|Afro) Futures 2023',
|
|
id: 'zUoZvkZ3J7Q',
|
|
params: 'start=10909',
|
|
},
|
|
//
|
|
{
|
|
title: 'boggo - Live Coding Metal Djents',
|
|
id: 'n0rhn9-PRwE',
|
|
description: 'A rare sight: live coded Metal Djents, where strudel is sending MIDI to bespoke synth!',
|
|
},
|
|
{
|
|
title: 'froos @ Solstice Night Stream December 2022',
|
|
id: 'P1DDsOvcyco',
|
|
params: 'start=19',
|
|
},
|
|
{ title: 'froos @ WAC 2022 Day', id: 'KWIotFWVOi4' },
|
|
{
|
|
title: 'yaxu & olivia - Algorithmic Pattern Live Stream',
|
|
id: 'Jvs7Q4cdLy4',
|
|
description:
|
|
'A first foray into combining (an early version) strudel and hydra, using flok for collaborative coding.',
|
|
},
|
|
{ title: 'froos @ Algorave 10th Birthday stream', id: 'IcMSocdKwvw' },
|
|
{ title: 'todepasta 1.5', id: 'gCwaVu1Mijg' },
|
|
{ title: 'Djenerative Music by Bogdan Vera @ TOPLAP solstice Dec 2024', id: 'LtMX4Lr1nzY' },
|
|
{ title: 'La musique by BuboBubo @ TOPLAP solstice Dec 2024', id: 'Oz00Y_f80wU' },
|
|
{ title: 'Livecode and vocal breaks by Switch Angel @ TOPLAP solstice Dec 2024', id: '2kzjOIsL6CM' },
|
|
{ title: 'Eddyflux algorave set @ rudolf5', id: 'MXz8131Ut0A' },
|
|
];
|
|
|
|
_shuffled = shuffleArray(_videos);
|