Compare commits
2 Commits
e86eee8744
...
513bfbda96
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
513bfbda96 | ||
|
|
c2135bbb5d |
@@ -33,7 +33,7 @@ services:
|
|||||||
build: ./nest-front
|
build: ./nest-front
|
||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
ports:
|
ports:
|
||||||
- "5173:5173"
|
- "80:80"
|
||||||
environment:
|
environment:
|
||||||
API_URL: http://api:3000
|
API_URL: http://api:3000
|
||||||
depends_on:
|
depends_on:
|
||||||
|
|||||||
@@ -1,15 +1,52 @@
|
|||||||
import { useEffect, useState } from 'react';
|
|
||||||
import { teamApi } from '../../utils/api';
|
|
||||||
import type { TeamMember } from '../../types';
|
import type { TeamMember } from '../../types';
|
||||||
|
|
||||||
export default function StudioPage() {
|
const FALLBACK_MEMBERS: TeamMember[] = [
|
||||||
const [members, setMembers] = useState<TeamMember[]>([]);
|
{
|
||||||
|
id: 'studio-1',
|
||||||
|
name: 'Thibault Pouch',
|
||||||
|
role: 'Game Dev • Lore / CI-CD',
|
||||||
|
bio: 'Works on game dev, game lore, CI/CD, assets, and the web platform.',
|
||||||
|
avatarInitials: 'TP',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 'studio-2',
|
||||||
|
name: 'Pierre Ryssen',
|
||||||
|
role: 'Game Dev • Assets / Web',
|
||||||
|
bio: 'Works on game dev, assets, and the web platform.',
|
||||||
|
avatarInitials: 'PR',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 'studio-3',
|
||||||
|
name: 'Antoine Papillon',
|
||||||
|
role: 'Game Dev • Gameplay',
|
||||||
|
bio: 'Focused on core game development for the project.',
|
||||||
|
avatarInitials: 'AP',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 'studio-4',
|
||||||
|
name: 'Clement Augustinowick',
|
||||||
|
role: 'Game Dev • Gameplay',
|
||||||
|
bio: 'Focused on core game development for the project.',
|
||||||
|
avatarInitials: 'CA',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 'studio-5',
|
||||||
|
name: 'Dany Lhoir',
|
||||||
|
role: 'Game Dev • Multiplayer / Security',
|
||||||
|
bio: 'Works on game dev, multiplayer systems, and cybersecurity.',
|
||||||
|
avatarInitials: 'DL',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 'studio-6',
|
||||||
|
name: 'Timote Koenig',
|
||||||
|
role: 'Game Dev • Assets / Planning',
|
||||||
|
bio: 'Works on game dev, assets, and project planning.',
|
||||||
|
avatarInitials: 'TK',
|
||||||
|
},
|
||||||
|
];
|
||||||
|
|
||||||
useEffect(() => {
|
export default function StudioPage() {
|
||||||
teamApi.getMembers()
|
const members = FALLBACK_MEMBERS;
|
||||||
.then(setMembers)
|
|
||||||
.catch(() => { /* show empty state */ });
|
|
||||||
}, []);
|
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div style={{ maxWidth: '1000px', margin: '0 auto', padding: '4rem 1.5rem' }}>
|
<div style={{ maxWidth: '1000px', margin: '0 auto', padding: '4rem 1.5rem' }}>
|
||||||
@@ -42,8 +79,8 @@ export default function StudioPage() {
|
|||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
CrowMate Studio is an independent game studio founded in 2023 by a team of six developers
|
CrowMate Studio is an independent game studio founded in 2023 by a team of six developers
|
||||||
united by a shared obsession: games that are strange, atmospheric, and actually interesting.
|
who are all new to game development and learning by building together. We are headquartered
|
||||||
We are headquartered somewhere in Europe and operate fully remote.
|
somewhere in Europe and operate fully remote.
|
||||||
</p>
|
</p>
|
||||||
<p
|
<p
|
||||||
style={{
|
style={{
|
||||||
@@ -60,6 +97,41 @@ export default function StudioPage() {
|
|||||||
you don't need a $200 million budget to make something that sticks.
|
you don't need a $200 million budget to make something that sticks.
|
||||||
</p>
|
</p>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div
|
||||||
|
className="crt-box"
|
||||||
|
style={{ padding: '1.5rem 2rem', display: 'grid', gridTemplateColumns: 'repeat(auto-fit, minmax(160px, 1fr))', gap: '1rem' }}
|
||||||
|
>
|
||||||
|
{[
|
||||||
|
{ label: 'TEAM SIZE', value: '6 PEOPLE' },
|
||||||
|
{ label: 'FOUNDED', value: '2026' },
|
||||||
|
{ label: 'WORK MODE', value: 'REMOTE' },
|
||||||
|
{ label: 'CURRENT GAME', value: 'HEADLESS HAZARD' },
|
||||||
|
].map(({ label, value }) => (
|
||||||
|
<div key={label}>
|
||||||
|
<div
|
||||||
|
style={{
|
||||||
|
fontFamily: 'var(--font-mono)',
|
||||||
|
color: 'var(--color-green)',
|
||||||
|
fontSize: '0.72rem',
|
||||||
|
letterSpacing: '0.08em',
|
||||||
|
marginBottom: '0.45rem',
|
||||||
|
}}
|
||||||
|
>
|
||||||
|
{label}
|
||||||
|
</div>
|
||||||
|
<div
|
||||||
|
style={{
|
||||||
|
fontFamily: 'var(--font-heading)',
|
||||||
|
color: 'var(--color-text)',
|
||||||
|
fontSize: '1rem',
|
||||||
|
}}
|
||||||
|
>
|
||||||
|
{value}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{/* History & Vision */}
|
{/* History & Vision */}
|
||||||
|
|||||||
Reference in New Issue
Block a user