Compare commits

12 Commits

Author SHA1 Message Date
22fab4c15e data for all cards entered, incorporated. some styling 2022-04-27 15:31:48 -05:00
ea4396380a thing is kind of broken 2022-04-20 17:59:02 -05:00
Mikayla Dobson
84f1191e03 Merge pull request #3 from innocuous-symmetry/gameboard-041622
Gameboard 041622
2022-04-16 14:23:08 -05:00
Mikayla Dobson
b272df9b39 player state passed into gameboard 2022-04-16 14:22:45 -05:00
Mikayla Dobson
42c15e2160 key mapping 2022-04-16 14:09:15 -05:00
Mikayla Dobson
f53645be8b local multi form writes to store 2022-04-16 13:58:27 -05:00
Mikayla Dobson
230655a872 setting up reducer/context structure 2022-04-16 13:28:26 -05:00
Mikayla Dobson
058e3263db Merge pull request #2 from innocuous-symmetry/gameboard-041622
Gameboard 041622
2022-04-16 12:35:50 -05:00
Mikayla Dobson
2b8d5045de basic rendering for all three card tiers 2022-04-16 12:35:08 -05:00
Mikayla Dobson
d115481718 card tier handling for game board rendering 2022-04-16 11:56:54 -05:00
Mikayla Dobson
9389dafa6b gameboard rendering for cards from card deck in store 2022-04-16 11:52:52 -05:00
Mikayla Dobson
a162f94005 Merge pull request #1 from innocuous-symmetry/mern-layout
Mern layout
2022-04-03 10:13:16 -05:00
35 changed files with 2163 additions and 103 deletions

BIN
.DS_Store vendored Normal file

Binary file not shown.

160
client/package-lock.json generated
View File

@@ -10,11 +10,14 @@
"dependencies": {
"@testing-library/jest-dom": "^5.16.3",
"@testing-library/react": "^12.1.4",
"@testing-library/react-hooks": "^8.0.0",
"@testing-library/user-event": "^13.5.0",
"react": "^18.0.0",
"react-dom": "^18.0.0",
"react": "^17.0.0",
"react-dom": "^17.0.0",
"react-router-dom": "^6.2.2",
"react-scripts": "5.0.0",
"sass": "^1.51.0",
"uuid": "^8.3.2",
"web-vitals": "^2.1.4"
}
},
@@ -3322,6 +3325,35 @@
"react-dom": "*"
}
},
"node_modules/@testing-library/react-hooks": {
"version": "8.0.0",
"resolved": "https://registry.npmjs.org/@testing-library/react-hooks/-/react-hooks-8.0.0.tgz",
"integrity": "sha512-uZqcgtcUUtw7Z9N32W13qQhVAD+Xki2hxbTR461MKax8T6Jr8nsUvZB+vcBTkzY2nFvsUet434CsgF0ncW2yFw==",
"dependencies": {
"@babel/runtime": "^7.12.5",
"react-error-boundary": "^3.1.0"
},
"engines": {
"node": ">=12"
},
"peerDependencies": {
"@types/react": "^16.9.0 || ^17.0.0",
"react": "^16.9.0 || ^17.0.0",
"react-dom": "^16.9.0 || ^17.0.0",
"react-test-renderer": "^16.9.0 || ^17.0.0"
},
"peerDependenciesMeta": {
"@types/react": {
"optional": true
},
"react-dom": {
"optional": true
},
"react-test-renderer": {
"optional": true
}
}
},
"node_modules/@testing-library/user-event": {
"version": "13.5.0",
"resolved": "https://registry.npmjs.org/@testing-library/user-event/-/user-event-13.5.0.tgz",
@@ -8245,6 +8277,11 @@
"url": "https://opencollective.com/immer"
}
},
"node_modules/immutable": {
"version": "4.0.0",
"resolved": "https://registry.npmjs.org/immutable/-/immutable-4.0.0.tgz",
"integrity": "sha512-zIE9hX70qew5qTUjSS7wi1iwj/l7+m54KWU247nhM3v806UdGj1yDndXj+IOYxxtW9zyLI+xqFNZjTuDaLUqFw=="
},
"node_modules/import-fresh": {
"version": "3.3.0",
"resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz",
@@ -13079,11 +13116,12 @@
}
},
"node_modules/react": {
"version": "18.0.0",
"resolved": "https://registry.npmjs.org/react/-/react-18.0.0.tgz",
"integrity": "sha512-x+VL6wbT4JRVPm7EGxXhZ8w8LTROaxPXOqhlGyVSrv0sB1jkyFGgXxJ8LVoPRLvPR6/CIZGFmfzqUa2NYeMr2A==",
"version": "17.0.2",
"resolved": "https://registry.npmjs.org/react/-/react-17.0.2.tgz",
"integrity": "sha512-gnhPt75i/dq/z3/6q/0asP78D0u592D5L1pd7M8P+dck6Fu/jJeL6iVVK23fptSUZj8Vjf++7wXA8UNclGQcbA==",
"dependencies": {
"loose-envify": "^1.1.0"
"loose-envify": "^1.1.0",
"object-assign": "^4.1.1"
},
"engines": {
"node": ">=0.10.0"
@@ -13223,15 +13261,31 @@
}
},
"node_modules/react-dom": {
"version": "18.0.0",
"resolved": "https://registry.npmjs.org/react-dom/-/react-dom-18.0.0.tgz",
"integrity": "sha512-XqX7uzmFo0pUceWFCt7Gff6IyIMzFUn7QMZrbrQfGxtaxXZIcGQzoNpRLE3fQLnS4XzLLPMZX2T9TRcSrasicw==",
"version": "17.0.2",
"resolved": "https://registry.npmjs.org/react-dom/-/react-dom-17.0.2.tgz",
"integrity": "sha512-s4h96KtLDUQlsENhMn1ar8t2bEa+q/YAtj8pPPdIjPDGBDIVNsrD9aXNWqspUe6AzKCIG0C1HZZLqLV7qpOBGA==",
"dependencies": {
"loose-envify": "^1.1.0",
"scheduler": "^0.21.0"
"object-assign": "^4.1.1",
"scheduler": "^0.20.2"
},
"peerDependencies": {
"react": "^18.0.0"
"react": "17.0.2"
}
},
"node_modules/react-error-boundary": {
"version": "3.1.4",
"resolved": "https://registry.npmjs.org/react-error-boundary/-/react-error-boundary-3.1.4.tgz",
"integrity": "sha512-uM9uPzZJTF6wRQORmSrvOIgt4lJ9MC1sNgEOj2XGsDTRE4kmpWxg7ENK9EWNKJRMAOY9z0MuF4yIfl6gp4sotA==",
"dependencies": {
"@babel/runtime": "^7.12.5"
},
"engines": {
"node": ">=10",
"npm": ">=6"
},
"peerDependencies": {
"react": ">=16.13.1"
}
},
"node_modules/react-error-overlay": {
@@ -13782,6 +13836,22 @@
"resolved": "https://registry.npmjs.org/sanitize.css/-/sanitize.css-13.0.0.tgz",
"integrity": "sha512-ZRwKbh/eQ6w9vmTjkuG0Ioi3HBwPFce0O+v//ve+aOq1oeCy7jMV2qzzAlpsNuqpqCBjjriM1lbtZbF/Q8jVyA=="
},
"node_modules/sass": {
"version": "1.51.0",
"resolved": "https://registry.npmjs.org/sass/-/sass-1.51.0.tgz",
"integrity": "sha512-haGdpTgywJTvHC2b91GSq+clTKGbtkkZmVAb82jZQN/wTy6qs8DdFm2lhEQbEwrY0QDRgSQ3xDurqM977C3noA==",
"dependencies": {
"chokidar": ">=3.0.0 <4.0.0",
"immutable": "^4.0.0",
"source-map-js": ">=0.6.2 <2.0.0"
},
"bin": {
"sass": "sass.js"
},
"engines": {
"node": ">=12.0.0"
}
},
"node_modules/sass-loader": {
"version": "12.6.0",
"resolved": "https://registry.npmjs.org/sass-loader/-/sass-loader-12.6.0.tgz",
@@ -13836,11 +13906,12 @@
}
},
"node_modules/scheduler": {
"version": "0.21.0",
"resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.21.0.tgz",
"integrity": "sha512-1r87x5fz9MXqswA2ERLo0EbOAU74DpIUO090gIasYTqlVoJeMcl+Z1Rg7WHz+qtPujhS/hGIt9kxZOYBV3faRQ==",
"version": "0.20.2",
"resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.20.2.tgz",
"integrity": "sha512-2eWfGgAqqWFGqtdMmcL5zCMK1U8KlXv8SQFGglL3CEtd0aDVDWgeF/YoCmvln55m5zSk3J/20hTaSBeSObsQDQ==",
"dependencies": {
"loose-envify": "^1.1.0"
"loose-envify": "^1.1.0",
"object-assign": "^4.1.1"
}
},
"node_modules/schema-utils": {
@@ -18364,6 +18435,15 @@
"@types/react-dom": "*"
}
},
"@testing-library/react-hooks": {
"version": "8.0.0",
"resolved": "https://registry.npmjs.org/@testing-library/react-hooks/-/react-hooks-8.0.0.tgz",
"integrity": "sha512-uZqcgtcUUtw7Z9N32W13qQhVAD+Xki2hxbTR461MKax8T6Jr8nsUvZB+vcBTkzY2nFvsUet434CsgF0ncW2yFw==",
"requires": {
"@babel/runtime": "^7.12.5",
"react-error-boundary": "^3.1.0"
}
},
"@testing-library/user-event": {
"version": "13.5.0",
"resolved": "https://registry.npmjs.org/@testing-library/user-event/-/user-event-13.5.0.tgz",
@@ -22022,6 +22102,11 @@
"resolved": "https://registry.npmjs.org/immer/-/immer-9.0.12.tgz",
"integrity": "sha512-lk7UNmSbAukB5B6dh9fnh5D0bJTOFKxVg2cyJWTYrWRfhLrLMBquONcUs3aFq507hNoIZEDDh8lb8UtOizSMhA=="
},
"immutable": {
"version": "4.0.0",
"resolved": "https://registry.npmjs.org/immutable/-/immutable-4.0.0.tgz",
"integrity": "sha512-zIE9hX70qew5qTUjSS7wi1iwj/l7+m54KWU247nhM3v806UdGj1yDndXj+IOYxxtW9zyLI+xqFNZjTuDaLUqFw=="
},
"import-fresh": {
"version": "3.3.0",
"resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz",
@@ -25364,11 +25449,12 @@
}
},
"react": {
"version": "18.0.0",
"resolved": "https://registry.npmjs.org/react/-/react-18.0.0.tgz",
"integrity": "sha512-x+VL6wbT4JRVPm7EGxXhZ8w8LTROaxPXOqhlGyVSrv0sB1jkyFGgXxJ8LVoPRLvPR6/CIZGFmfzqUa2NYeMr2A==",
"version": "17.0.2",
"resolved": "https://registry.npmjs.org/react/-/react-17.0.2.tgz",
"integrity": "sha512-gnhPt75i/dq/z3/6q/0asP78D0u592D5L1pd7M8P+dck6Fu/jJeL6iVVK23fptSUZj8Vjf++7wXA8UNclGQcbA==",
"requires": {
"loose-envify": "^1.1.0"
"loose-envify": "^1.1.0",
"object-assign": "^4.1.1"
}
},
"react-app-polyfill": {
@@ -25471,12 +25557,21 @@
}
},
"react-dom": {
"version": "18.0.0",
"resolved": "https://registry.npmjs.org/react-dom/-/react-dom-18.0.0.tgz",
"integrity": "sha512-XqX7uzmFo0pUceWFCt7Gff6IyIMzFUn7QMZrbrQfGxtaxXZIcGQzoNpRLE3fQLnS4XzLLPMZX2T9TRcSrasicw==",
"version": "17.0.2",
"resolved": "https://registry.npmjs.org/react-dom/-/react-dom-17.0.2.tgz",
"integrity": "sha512-s4h96KtLDUQlsENhMn1ar8t2bEa+q/YAtj8pPPdIjPDGBDIVNsrD9aXNWqspUe6AzKCIG0C1HZZLqLV7qpOBGA==",
"requires": {
"loose-envify": "^1.1.0",
"scheduler": "^0.21.0"
"object-assign": "^4.1.1",
"scheduler": "^0.20.2"
}
},
"react-error-boundary": {
"version": "3.1.4",
"resolved": "https://registry.npmjs.org/react-error-boundary/-/react-error-boundary-3.1.4.tgz",
"integrity": "sha512-uM9uPzZJTF6wRQORmSrvOIgt4lJ9MC1sNgEOj2XGsDTRE4kmpWxg7ENK9EWNKJRMAOY9z0MuF4yIfl6gp4sotA==",
"requires": {
"@babel/runtime": "^7.12.5"
}
},
"react-error-overlay": {
@@ -25875,6 +25970,16 @@
"resolved": "https://registry.npmjs.org/sanitize.css/-/sanitize.css-13.0.0.tgz",
"integrity": "sha512-ZRwKbh/eQ6w9vmTjkuG0Ioi3HBwPFce0O+v//ve+aOq1oeCy7jMV2qzzAlpsNuqpqCBjjriM1lbtZbF/Q8jVyA=="
},
"sass": {
"version": "1.51.0",
"resolved": "https://registry.npmjs.org/sass/-/sass-1.51.0.tgz",
"integrity": "sha512-haGdpTgywJTvHC2b91GSq+clTKGbtkkZmVAb82jZQN/wTy6qs8DdFm2lhEQbEwrY0QDRgSQ3xDurqM977C3noA==",
"requires": {
"chokidar": ">=3.0.0 <4.0.0",
"immutable": "^4.0.0",
"source-map-js": ">=0.6.2 <2.0.0"
}
},
"sass-loader": {
"version": "12.6.0",
"resolved": "https://registry.npmjs.org/sass-loader/-/sass-loader-12.6.0.tgz",
@@ -25898,11 +26003,12 @@
}
},
"scheduler": {
"version": "0.21.0",
"resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.21.0.tgz",
"integrity": "sha512-1r87x5fz9MXqswA2ERLo0EbOAU74DpIUO090gIasYTqlVoJeMcl+Z1Rg7WHz+qtPujhS/hGIt9kxZOYBV3faRQ==",
"version": "0.20.2",
"resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.20.2.tgz",
"integrity": "sha512-2eWfGgAqqWFGqtdMmcL5zCMK1U8KlXv8SQFGglL3CEtd0aDVDWgeF/YoCmvln55m5zSk3J/20hTaSBeSObsQDQ==",
"requires": {
"loose-envify": "^1.1.0"
"loose-envify": "^1.1.0",
"object-assign": "^4.1.1"
}
},
"schema-utils": {

View File

@@ -5,11 +5,14 @@
"dependencies": {
"@testing-library/jest-dom": "^5.16.3",
"@testing-library/react": "^12.1.4",
"@testing-library/react-hooks": "^8.0.0",
"@testing-library/user-event": "^13.5.0",
"react": "^18.0.0",
"react-dom": "^18.0.0",
"react": "^17.0.0",
"react-dom": "^17.0.0",
"react-router-dom": "^6.2.2",
"react-scripts": "5.0.0",
"sass": "^1.51.0",
"uuid": "^8.3.2",
"web-vitals": "^2.1.4"
},
"scripts": {

View File

@@ -1,38 +0,0 @@
.App {
text-align: center;
}
.App-logo {
height: 40vmin;
pointer-events: none;
}
@media (prefers-reduced-motion: no-preference) {
.App-logo {
animation: App-logo-spin infinite 20s linear;
}
}
.App-header {
background-color: #282c34;
min-height: 100vh;
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
font-size: calc(10px + 2vmin);
color: white;
}
.App-link {
color: #61dafb;
}
@keyframes App-logo-spin {
from {
transform: rotate(0deg);
}
to {
transform: rotate(360deg);
}
}

View File

@@ -1,17 +1,22 @@
import './App.css';
import './styles/App.css';
import { Routes, Route, BrowserRouter } from 'react-router-dom';
import Welcome from './components/Welcome';
import FulLGameView from './components/Game/FullGameView';
import Store from './store/Store';
function App() {
return (
<div className="App">
<BrowserRouter>
<Routes>
<Route path="/" element={<Welcome />}/>
</Routes>
</BrowserRouter>
</div>
<Store>
<div className="App">
<BrowserRouter>
<Routes>
<Route path="/" element={<Welcome />}/>
<Route path="/gameboard" element={<FulLGameView />}/>
</Routes>
</BrowserRouter>
</div>
</Store>
);
}

View File

@@ -1,8 +0,0 @@
import { render, screen } from '@testing-library/react';
import App from './App';
test('renders learn react link', () => {
render(<App />);
const linkElement = screen.getByText(/learn react/i);
expect(linkElement).toBeInTheDocument();
});

View File

@@ -1,16 +1,28 @@
export default class Card {
constructor(state) {
this.state = {
tier: state.tier,
points: state.points,
isWorth: state.worth,
cost: {
acorns: state.cost.acorns,
pineCones: state.cost.pineCones,
walnuts: state.cost.walnuts,
apples: state.cost.apples,
twigs: state.cost.twigs
}
};
import '../../styles/Card.scss';
export default function Card({ tier, props }) {
const { points, isWorth, cost } = props;
const mapCosts = () => {
let allCosts = [];
for (let [key, value] of Object.entries(cost)) {
if (value < 1) continue;
allCosts.push(<>{value} {key}<br/></>);
}
return allCosts;
}
return (
<div className={`card ${isWorth}`}>
<div className="card-row">
<div className="value">{isWorth}</div>
<div className="points">{points} points</div>
</div>
<div className="card-row bottom-row">
<div className={`tier tier-${tier}`}></div>
<div className="costs">Costs:<br/> {mapCosts()}</div>
</div>
</div>
)
}

View File

@@ -0,0 +1,29 @@
import { useEffect, useState } from "react";
export function DeckCard({ tier }) {
const [tierDots, setTierDots] = useState(null);
useEffect(() => {
const singleDot = <div className="tier-dot"></div>
const mapDots = () => {
let iter = 0;
let newState = [];
while (iter < tier) {
iter++;
newState.push(singleDot);
}
setTierDots(newState);
}
mapDots();
}, [])
return (
<div className={`deck-card-${tier} card`}>
<div className="card-logo">SPLINTER</div>
<div className="tier-row">
{tierDots}
</div>
</div>
)
}

View File

@@ -0,0 +1,9 @@
import GameBoard from "./GameBoard";
export default function FulLGameView() {
return (
<>
<GameBoard />
</>
)
}

View File

@@ -0,0 +1,89 @@
import { useContext, useEffect, useState } from 'react';
import { Context } from '../../store/Store';
import '../../styles/GameBoard.css';
import Card from '../Cards/Card';
import { DeckCard } from '../Cards/DeckCard';
import jsonCards from '../../store/cards.json';
export default function GameBoard() {
const [state, dispatch] = useContext(Context);
const [trigger, setTrigger] = useState(true);
const [rowThree, setRowThree] = useState(null);
const [rowTwo, setRowTwo] = useState(null);
const [rowOne, setRowOne] = useState(null);
const { tierOne, tierTwo, tierThree } = jsonCards;
useEffect(() => {
const AllDecks = [tierOne, tierTwo, tierThree];
// param limit sets limit on number of cards rendered
const buildGameBoardRow = (limit, tier) => {
let newBoard = [<DeckCard tier={tier} />];
let i = 0;
while (i < limit) {
i++;
if (!AllDecks[tier-1][i-1]) continue;
newBoard.push(<Card tier={tier} props={AllDecks[tier-1][i-1]} />);
}
switch (tier) {
case 1:
setRowOne(newBoard);
setTrigger(false);
break;
case 2:
setRowTwo(newBoard);
setTrigger(false);
break;
case 3:
setRowThree(newBoard);
setTrigger(false);
break;
default:
setTrigger(false);
break;
}
}
if (trigger) {
buildGameBoardRow(4,3);
buildGameBoardRow(4,2);
buildGameBoardRow(4,1);
}
}, [trigger]);
return (
<div className="gameboard">
<a href='/' className="gameboard-title">SPLINTER</a>
<div>
<h2>Players:</h2>
{state.players.map(player => {
return (
<div className="player-info">
<p>{player.name}</p>
<p>{player.points && `Score: ${player.points}`}</p>
</div>
)
})
}
</div>
<div className="gameboard-row">
{rowThree || 'Loading'}
</div>
<div className="gameboard-row">
{rowTwo || 'Loading'}
</div>
<div className="gameboard-row">
{rowOne || 'Loading'}
</div>
<div className="section-border"></div>
</div>
)
}

View File

@@ -1,4 +1,4 @@
import Card from "./Card";
import Card from "../Cards/Card";
export default class Inventory {
constructor(state) {

View File

@@ -0,0 +1,11 @@
import { useState } from "react"
export default function PlayerInventory({ name }) {
const [materials, setMaterials] = useState(null);
return (
<>
</>
)
}

View File

@@ -2,6 +2,7 @@ export default function CpuMultiForm() {
return (
<form className="local-multi-form">
<h1>AI and stuff?</h1>
<h2>Coming soon!</h2>
</form>
)
}

View File

@@ -1,6 +1,11 @@
import { useState, useEffect } from "react";
import { useState, useEffect, useContext } from "react";
import { Context } from "../../store/Store";
import { useNavigate } from "react-router-dom";
export default function LocalMultiForm() {
const [state, dispatch] = useContext(Context);
const navigate = useNavigate();
const [players, setPlayers] = useState(null);
const [formVariant, setFormVariant] = useState(null);
const [playerOne, setPlayerOne] = useState('');
@@ -8,6 +13,8 @@ export default function LocalMultiForm() {
const [playerThree, setPlayerThree] = useState('');
const [playerFour, setPlayerFour] = useState('');
const allPlayerNames = [playerOne, playerTwo, playerThree, playerFour];
const formVariants = [
<> { /* Fragment, expects to be concatenated as necessary within a <form> element */ }
{ /* Player one and two base; index 0 */ }
@@ -47,6 +54,43 @@ export default function LocalMultiForm() {
}
}, [players]);
const handleStartGame = () => {
let toSubmit = [];
let iter = 0;
while (iter < players) {
toSubmit.push({
name: allPlayerNames[iter],
tokens: {
cedar: 0,
aspen: 0,
walnut: 0,
mahogany: 0,
cherry: 0,
resin: 0,
},
cards: {
cedar: 0,
aspen: 0,
walnut: 0,
mahogany: 0,
cherry: 0,
},
points: 0,
spirits: 0,
});
iter++;
}
if (toSubmit.length < players) return;
for (let item of toSubmit) {
if (!item) return;
}
dispatch({ type: "ADD PLAYERS", payload: toSubmit });
navigate('/gameboard');
}
return (
<>
<form className="local-multi-form" style={{paddingBottom: '2rem'}}>
@@ -69,6 +113,8 @@ export default function LocalMultiForm() {
<form className="player-input" style={{paddingBottom: '1rem'}}>
{formVariant}
</form>
<button onClick={handleStartGame}>Start game</button>
<button onClick={() => dispatch({type: "PRINT PLAYERS"})}>Get Players</button>
</>
)
}

View File

@@ -1,8 +1,11 @@
import { useState, useRef } from "react"
import { useState, useRef, useContext } from "react"
import LocalMultiForm from "./GameConfigForms/LocalMultiForm";
import CpuMultiForm from "./GameConfigForms/CpuMultiForm";
import { Context } from "../store/Store";
export default function Welcome() {
const [state, dispatch] = useContext(Context);
const [localMulti, setLocalMulti] = useState(false);
const [cpuMulti, setCpuMulti] = useState(false);
@@ -50,7 +53,7 @@ export default function Welcome() {
</form>
{localMulti ? <LocalMultiForm /> : null}
{cpuMulti ? <CpuMultiForm /> : null}
{cpuMulti ? <CpuMultiForm /> : null}
<button onClick={handleClear}>Clear form input</button>
</>

View File

@@ -1,6 +1,6 @@
import React from 'react';
import ReactDOM from 'react-dom';
import './index.css';
import './styles/index.css';
import App from './App';
import reportWebVitals from './reportWebVitals';

View File

@@ -1 +0,0 @@
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 841.9 595.3"><g fill="#61DAFB"><path d="M666.3 296.5c0-32.5-40.7-63.3-103.1-82.4 14.4-63.6 8-114.2-20.2-130.4-6.5-3.8-14.1-5.6-22.4-5.6v22.3c4.6 0 8.3.9 11.4 2.6 13.6 7.8 19.5 37.5 14.9 75.7-1.1 9.4-2.9 19.3-5.1 29.4-19.6-4.8-41-8.5-63.5-10.9-13.5-18.5-27.5-35.3-41.6-50 32.6-30.3 63.2-46.9 84-46.9V78c-27.5 0-63.5 19.6-99.9 53.6-36.4-33.8-72.4-53.2-99.9-53.2v22.3c20.7 0 51.4 16.5 84 46.6-14 14.7-28 31.4-41.3 49.9-22.6 2.4-44 6.1-63.6 11-2.3-10-4-19.7-5.2-29-4.7-38.2 1.1-67.9 14.6-75.8 3-1.8 6.9-2.6 11.5-2.6V78.5c-8.4 0-16 1.8-22.6 5.6-28.1 16.2-34.4 66.7-19.9 130.1-62.2 19.2-102.7 49.9-102.7 82.3 0 32.5 40.7 63.3 103.1 82.4-14.4 63.6-8 114.2 20.2 130.4 6.5 3.8 14.1 5.6 22.5 5.6 27.5 0 63.5-19.6 99.9-53.6 36.4 33.8 72.4 53.2 99.9 53.2 8.4 0 16-1.8 22.6-5.6 28.1-16.2 34.4-66.7 19.9-130.1 62-19.1 102.5-49.9 102.5-82.3zm-130.2-66.7c-3.7 12.9-8.3 26.2-13.5 39.5-4.1-8-8.4-16-13.1-24-4.6-8-9.5-15.8-14.4-23.4 14.2 2.1 27.9 4.7 41 7.9zm-45.8 106.5c-7.8 13.5-15.8 26.3-24.1 38.2-14.9 1.3-30 2-45.2 2-15.1 0-30.2-.7-45-1.9-8.3-11.9-16.4-24.6-24.2-38-7.6-13.1-14.5-26.4-20.8-39.8 6.2-13.4 13.2-26.8 20.7-39.9 7.8-13.5 15.8-26.3 24.1-38.2 14.9-1.3 30-2 45.2-2 15.1 0 30.2.7 45 1.9 8.3 11.9 16.4 24.6 24.2 38 7.6 13.1 14.5 26.4 20.8 39.8-6.3 13.4-13.2 26.8-20.7 39.9zm32.3-13c5.4 13.4 10 26.8 13.8 39.8-13.1 3.2-26.9 5.9-41.2 8 4.9-7.7 9.8-15.6 14.4-23.7 4.6-8 8.9-16.1 13-24.1zM421.2 430c-9.3-9.6-18.6-20.3-27.8-32 9 .4 18.2.7 27.5.7 9.4 0 18.7-.2 27.8-.7-9 11.7-18.3 22.4-27.5 32zm-74.4-58.9c-14.2-2.1-27.9-4.7-41-7.9 3.7-12.9 8.3-26.2 13.5-39.5 4.1 8 8.4 16 13.1 24 4.7 8 9.5 15.8 14.4 23.4zM420.7 163c9.3 9.6 18.6 20.3 27.8 32-9-.4-18.2-.7-27.5-.7-9.4 0-18.7.2-27.8.7 9-11.7 18.3-22.4 27.5-32zm-74 58.9c-4.9 7.7-9.8 15.6-14.4 23.7-4.6 8-8.9 16-13 24-5.4-13.4-10-26.8-13.8-39.8 13.1-3.1 26.9-5.8 41.2-7.9zm-90.5 125.2c-35.4-15.1-58.3-34.9-58.3-50.6 0-15.7 22.9-35.6 58.3-50.6 8.6-3.7 18-7 27.7-10.1 5.7 19.6 13.2 40 22.5 60.9-9.2 20.8-16.6 41.1-22.2 60.6-9.9-3.1-19.3-6.5-28-10.2zM310 490c-13.6-7.8-19.5-37.5-14.9-75.7 1.1-9.4 2.9-19.3 5.1-29.4 19.6 4.8 41 8.5 63.5 10.9 13.5 18.5 27.5 35.3 41.6 50-32.6 30.3-63.2 46.9-84 46.9-4.5-.1-8.3-1-11.3-2.7zm237.2-76.2c4.7 38.2-1.1 67.9-14.6 75.8-3 1.8-6.9 2.6-11.5 2.6-20.7 0-51.4-16.5-84-46.6 14-14.7 28-31.4 41.3-49.9 22.6-2.4 44-6.1 63.6-11 2.3 10.1 4.1 19.8 5.2 29.1zm38.5-66.7c-8.6 3.7-18 7-27.7 10.1-5.7-19.6-13.2-40-22.5-60.9 9.2-20.8 16.6-41.1 22.2-60.6 9.9 3.1 19.3 6.5 28.1 10.2 35.4 15.1 58.3 34.9 58.3 50.6-.1 15.7-23 35.6-58.4 50.6zM320.8 78.4z"/><circle cx="420.9" cy="296.5" r="45.7"/><path d="M520.5 78.1z"/></g></svg>

Before

Width:  |  Height:  |  Size: 2.6 KiB

View File

@@ -0,0 +1,52 @@
export const Spirits = [
{
img: 'img src',
cost: {
cedar: 7,
aspen: 0,
walnut: 0,
mahogany: 0,
cherry: 0
}
},
{
img: 'img src',
cost: {
cedar: 7,
aspen: 0,
walnut: 0,
mahogany: 0,
cherry: 0
}
},
{
img: 'img src',
cost: {
cedar: 7,
aspen: 0,
walnut: 0,
mahogany: 0,
cherry: 0
}
},
{
img: 'img src',
cost: {
cedar: 7,
aspen: 0,
walnut: 0,
mahogany: 0,
cherry: 0
}
},
{
img: 'img src',
cost: {
cedar: 7,
aspen: 0,
walnut: 0,
mahogany: 0,
cherry: 0
}
},
]

58
client/src/store/Store.js Normal file
View File

@@ -0,0 +1,58 @@
import { useReducer, createContext } from "react"
import { TierOneDeck } from './TierOneDeck';
import { TierTwoDeck } from './TierTwoDeck';
import { TierThreeDeck } from './TierThreeDeck';
import { Spirits } from './Spirits';
const initialGameState = {
players: [{name: 'no players', inventory: null, cards: null}],
materials: {
cards: {
tierOneRemaining: TierOneDeck,
tierTwoRemaining: TierTwoDeck,
tierThreeRemaining: TierThreeDeck,
},
tokens: {
cedar: 7,
aspen: 7,
walnut: 7,
mahogany: 7,
cherry: 7,
resin: 5,
},
spirits: [...Spirits]
},
}
const reducer = (state, action) => {
switch (action.type) {
case "GET PLAYERS":
return state;
case "ADD PLAYERS":
state.players = action.payload;
return state;
case "UPDATE PLAYER MATERIALS":
// find player in array of players and update their resources
// update list of available materials in state
break;
case "PRINT PLAYERS":
console.log(state.players);
return state;
default:
break;
}
}
export default function Store({ children }) {
const [state, dispatch] = useReducer(reducer, initialGameState);
return (
<Context.Provider value={[state, dispatch]}>
{ children }
</Context.Provider>
)
}
export const Context = createContext(initialGameState);

View File

@@ -0,0 +1,189 @@
export const TierOneDeck = [
// TIER ONE CARDS
// total: 40
// cat 1: [2,1] cost cards
{
tier: 1,
points: 0,
isWorth: 'walnut',
cost: {
cedar: 2,
aspen: 1,
walnut: 0,
mahogany: 0,
cherry: 0
}
},
{
tier: 1,
points: 0,
isWorth: 'mahogany',
cost: {
cedar: 0,
aspen: 2,
walnut: 1,
mahogany: 0,
cherry: 0
}
},
{
tier: 1,
points: 0,
isWorth: 'cherry',
cost: {
cedar: 0,
aspen: 0,
walnut: 2,
mahogany: 1,
cherry: 0
}
},
{
tier: 1,
points: 0,
isWorth: 'cedar',
cost: {
cedar: 0,
aspen: 0,
walnut: 0,
mahogany: 2,
cherry: 1
}
},
{
tier: 1,
points: 0,
isWorth: 'aspen',
cost: {
cedar: 1,
aspen: 0,
walnut: 0,
mahogany: 0,
cherry: 2
}
},
// cat 2: 3 of a kind cost
{
tier: 1,
points: 0,
isWorth: 'cedar',
cost: {
cedar: 3,
aspen: 0,
walnut: 0,
mahogany: 0,
cherry: 0
}
},
{
tier: 1,
points: 0,
isWorth: 'aspen',
cost: {
cedar: 0,
aspen: 3,
walnut: 0,
mahogany: 0,
cherry: 0
}
},
{
tier: 1,
points: 0,
isWorth: 'walnut',
cost: {
cedar: 0,
aspen: 0,
walnut: 3,
mahogany: 0,
cherry: 0
}
},
{
tier: 1,
points: 0,
isWorth: 'mahogany',
cost: {
cedar: 0,
aspen: 0,
walnut: 0,
mahogany: 3,
cherry: 0
}
},
{
tier: 1,
points: 0,
isWorth: 'cherry',
cost: {
cedar: 0,
aspen: 0,
walnut: 0,
mahogany: 0,
cherry: 3
}
},
// cat 3: 4 of a kind, one point
{
tier: 1,
points: 1,
isWorth: 'cedar',
cost: {
cedar: 4,
aspen: 0,
walnut: 0,
mahogany: 0,
cherry: 0
}
},
{
tier: 1,
points: 1,
isWorth: 'aspen',
cost: {
cedar: 0,
aspen: 4,
walnut: 0,
mahogany: 0,
cherry: 0
}
},
{
tier: 1,
points: 1,
isWorth: 'walnut',
cost: {
cedar: 0,
aspen: 0,
walnut: 4,
mahogany: 0,
cherry: 0
}
},
{
tier: 1,
points: 1,
isWorth: 'mahogany',
cost: {
cedar: 0,
aspen: 0,
walnut: 0,
mahogany: 4,
cherry: 0
}
},
{
tier: 1,
points: 1,
isWorth: 'cherry',
cost: {
cedar: 0,
aspen: 0,
walnut: 0,
mahogany: 0,
cherry: 4
}
},
]

View File

@@ -0,0 +1,115 @@
export const TierThreeDeck = [
// TIER THREE CARDS
// total: 20
// cat 1: 7 of a kind
{
tier: 3,
points: 5,
isWorth: 'cedar',
cost: {
cedar: 7,
aspen: 0,
walnut: 0,
mahogany: 0,
cherry: 0
}
},
{
tier: 3,
points: 5,
isWorth: 'aspen',
cost: {
cedar: 0,
aspen: 7,
walnut: 0,
mahogany: 0,
cherry: 0
}
},
{
tier: 3,
points: 5,
isWorth: 'walnut',
cost: {
cedar: 0,
aspen: 0,
walnut: 7,
mahogany: 0,
cherry: 0
}
},
{
tier: 3,
points: 5,
isWorth: 'mahogany',
cost: {
cedar: 0,
aspen: 0,
walnut: 0,
mahogany: 7,
cherry: 0
}
},
{
tier: 3,
points: 5,
isWorth: 'cherry',
cost: {
cedar: 0,
aspen: 0,
walnut: 0,
mahogany: 0,
cherry: 7
}
},
// cat 2: [7,3] cost cards
{
tier: 2,
points: 5,
isWorth: 'cedar',
cost: {
cedar: 7,
aspen: 3,
walnut: 0,
mahogany: 0,
cherry: 0
}
},
{
tier: 2,
points: 5,
isWorth: 'aspen',
cost: {
cedar: 0,
aspen: 7,
walnut: 3,
mahogany: 0,
cherry: 0
}
},
{
tier: 2,
points: 5,
isWorth: 'walnut',
cost: {
cedar: 0,
aspen: 0,
walnut: 7,
mahogany: 3,
cherry: 0
}
},
{
tier: 2,
points: 5,
isWorth: 'mahogany',
cost: {
cedar: 0,
aspen: 0,
walnut: 0,
mahogany: 7,
cherry: 3
}
},
]

View File

@@ -0,0 +1,54 @@
export const TierTwoDeck = [
// TIER TWO CARDS
// total: 30
// cat 1: [5,3] cost cards
{
tier: 2,
points: 3,
isWorth: 'cedar',
cost: {
cedar: 5,
aspen: 3,
walnut: 0,
mahogany: 0,
cherry: 0
}
},
{
tier: 2,
points: 3,
isWorth: 'aspen',
cost: {
cedar: 0,
aspen: 5,
walnut: 3,
mahogany: 0,
cherry: 0
}
},
{
tier: 2,
points: 3,
isWorth: 'walnut',
cost: {
cedar: 0,
aspen: 0,
walnut: 5,
mahogany: 3,
cherry: 0
}
},
{
tier: 2,
points: 3,
isWorth: 'mahogany',
cost: {
cedar: 0,
aspen: 0,
walnut: 0,
mahogany: 5,
cherry: 3
}
},
]

View File

@@ -0,0 +1,76 @@
const allCards = [
{
tier: 1,
points: 0,
isWorth: 'cedar',
cost: {
cedar: 3,
aspen: 0,
walnut: 0,
mahogany: 0,
cherry: 0
}
},
{
tier: 1,
points: 0,
isWorth: 'aspen',
cost: {
cedar: 0,
aspen: 3,
walnut: 0,
mahogany: 0,
cherry: 0
}
},
{
tier: 1,
points: 0,
isWorth: 'walnut',
cost: {
cedar: 0,
aspen: 0,
walnut: 3,
mahogany: 0,
cherry: 0
}
},
{
tier: 1,
points: 0,
isWorth: 'mahogany',
cost: {
cedar: 0,
aspen: 0,
walnut: 0,
mahogany: 3,
cherry: 0
}
},
{
tier: 1,
points: 0,
isWorth: 'cherry',
cost: {
cedar: 0,
aspen: 0,
walnut: 0,
mahogany: 0,
cherry: 3
}
},
{
tier: 1,
points: 0,
isWorth: 'cedar',
cost: {
cedar: 3,
aspen: 0,
walnut: 0,
mahogany: 0,
cherry: 0
}
}
]
module.exports = allCards;

998
client/src/store/cards.json Normal file
View File

@@ -0,0 +1,998 @@
{
"tierOne": [
{
"cost": {
"cherry": 1,
"walnut": 1,
"cedar": 1,
"mahogany": 1,
"aspen": 0
},
"isWorth": "aspen",
"points": 0
},
{
"cost": {
"cherry": 1,
"walnut": 1,
"cedar": 0,
"mahogany": 1,
"aspen": 1
},
"isWorth": "cedar",
"points": 0
},
{
"cost": {
"cherry": 1,
"walnut": 1,
"cedar": 1,
"mahogany": 0,
"aspen": 1
},
"isWorth": "mahogany",
"points": 0
},
{
"cost": {
"cherry": 1,
"walnut": 0,
"cedar": 1,
"mahogany": 1,
"aspen": 1
},
"isWorth": "walnut",
"points": 0
},
{
"cost": {
"cherry": 0,
"walnut": 1,
"cedar": 1,
"mahogany": 1,
"aspen": 1
},
"isWorth": "cherry",
"points": 0
},
{
"cost": {
"cherry": 1,
"walnut": 2,
"cedar": 0,
"mahogany": 0,
"aspen": 2
},
"isWorth": "mahogany",
"points": 0
},
{
"cost": {
"cherry": 1,
"walnut": 0,
"cedar": 2,
"mahogany": 0,
"aspen": 0
},
"isWorth": "mahogany",
"points": 0
},
{
"cost": {
"cherry": 0,
"walnut": 3,
"cedar": 1,
"mahogany": 0,
"aspen": 1
},
"isWorth": "cedar",
"points": 0
},
{
"cost": {
"cherry": 1,
"walnut": 1,
"cedar": 3,
"mahogany": 0,
"aspen": 0
},
"isWorth": "walnut",
"points": 0
},
{
"cost": {
"cherry": 0,
"walnut": 0,
"cedar": 0,
"mahogany": 2,
"aspen": 1
},
"isWorth": "walnut",
"points": 0
},
{
"cost": {
"cherry": 1,
"walnut": 1,
"cedar": 2,
"mahogany": 1,
"aspen": 0
},
"isWorth": "aspen",
"points": 0
},
{
"cost": {
"cherry": 0,
"walnut": 1,
"cedar": 1,
"mahogany": 1,
"aspen": 2
},
"isWorth": "cherry",
"points": 0
},
{
"cost": {
"cherry": 0,
"walnut": 0,
"cedar": 1,
"mahogany": 1,
"aspen": 2
},
"isWorth": "cherry",
"points": 0
},
{
"cost": {
"cherry": 2,
"walnut": 0,
"cedar": 1,
"mahogany": 1,
"aspen": 1
},
"isWorth": "walnut",
"points": 0
},
{
"cost": {
"cherry": 0,
"walnut": 2,
"cedar": 2,
"mahogany": 1,
"aspen": 0
},
"isWorth": "aspen",
"points": 0
},
{
"cost": {
"cherry": 1,
"walnut": 2,
"cedar": 1,
"mahogany": 0,
"aspen": 1
},
"isWorth": "mahogany",
"points": 0
},
{
"cost": {
"cherry": 0,
"walnut": 2,
"cedar": 1,
"mahogany": 0,
"aspen": 0
},
"isWorth": "cherry",
"points": 0
},
{
"cost": {
"cherry": 1,
"walnut": 0,
"cedar": 0,
"mahogany": 3,
"aspen": 1
},
"isWorth": "cherry",
"points": 0
},
{
"cost": {
"cherry": 0,
"walnut": 1,
"cedar": 0,
"mahogany": 1,
"aspen": 3
},
"isWorth": "aspen",
"points": 0
},
{
"cost": {
"cherry": 2,
"walnut": 0,
"cedar": 0,
"mahogany": 1,
"aspen": 0
},
"isWorth": "aspen",
"points": 0
},
{
"cost": {
"cherry": 0,
"walnut": 1,
"cedar": 0,
"mahogany": 0,
"aspen": 2
},
"isWorth": "cedar",
"points": 0
},
{
"cost": {
"cherry": 1,
"walnut": 1,
"cedar": 0,
"mahogany": 2,
"aspen": 1
},
"isWorth": "cedar",
"points": 0
},
{
"cost": {
"cherry": 2,
"walnut": 1,
"cedar": 0,
"mahogany": 1,
"aspen": 0
},
"isWorth": "cedar",
"points": 0
},
{
"cost": {
"cherry": 3,
"walnut": 0,
"cedar": 1,
"mahogany": 1,
"aspen": 0
},
"isWorth": "mahogany",
"points": 0
},
{
"cost": {
"cherry": 2,
"walnut": 0,
"cedar": 2,
"mahogany": 0,
"aspen": 1
},
"isWorth": "walnut",
"points": 0
},
{
"cost": {
"cherry": 0,
"walnut": 0,
"cedar": 2,
"mahogany": 0,
"aspen": 2
},
"isWorth": "mahogany",
"points": 0
},
{
"cost": {
"cherry": 0,
"walnut": 2,
"cedar": 0,
"mahogany": 2,
"aspen": 0
},
"isWorth": "aspen",
"points": 0
},
{
"cost": {
"cherry": 2,
"walnut": 2,
"cedar": 0,
"mahogany": 0,
"aspen": 0
},
"isWorth": "cedar",
"points": 0
},
{
"cost": {
"cherry": 2,
"walnut": 0,
"cedar": 0,
"mahogany": 0,
"aspen": 2
},
"isWorth": "cherry",
"points": 0
},
{
"cost": {
"cherry": 0,
"walnut": 0,
"cedar": 2,
"mahogany": 2,
"aspen": 0
},
"isWorth": "walnut",
"points": 0
},
{
"cost": {
"cherry": 0,
"walnut": 0,
"cedar": 0,
"mahogany": 3,
"aspen": 0
},
"isWorth": "walnut",
"points": 0
},
{
"cost": {
"cherry": 0,
"walnut": 0,
"cedar": 0,
"mahogany": 0,
"aspen": 3
},
"isWorth": "cherry",
"points": 0
},
{
"cost": {
"cherry": 0,
"walnut": 0,
"cedar": 3,
"mahogany": 0,
"aspen": 0
},
"isWorth": "mahogany",
"points": 0
},
{
"cost": {
"cherry": 3,
"walnut": 0,
"cedar": 0,
"mahogany": 0,
"aspen": 0
},
"isWorth": "cedar",
"points": 0
},
{
"cost": {
"cherry": 0,
"walnut": 3,
"cedar": 0,
"mahogany": 0,
"aspen": 0
},
"isWorth": "aspen",
"points": 0
},
{
"cost": {
"cherry": 4,
"walnut": 0,
"cedar": 0,
"mahogany": 0,
"aspen": 0
},
"isWorth": "walnut",
"points": 1
},
{
"cost": {
"cherry": 0,
"walnut": 0,
"cedar": 0,
"mahogany": 0,
"aspen": 4
},
"isWorth": "cherry",
"points": 1
},
{
"cost": {
"cherry": 0,
"walnut": 4,
"cedar": 0,
"mahogany": 0,
"aspen": 0
},
"isWorth": "mahogany",
"points": 1
},
{
"cost": {
"cherry": 0,
"walnut": 0,
"cedar": 4,
"mahogany": 0,
"aspen": 0
},
"isWorth": "aspen",
"points": 1
},
{
"cost": {
"cherry": 0,
"walnut": 0,
"cedar": 0,
"mahogany": 4,
"aspen": 0
},
"isWorth": "cedar",
"points": 1
}
],
"tierTwo": [
{
"cost": {
"cherry": 0,
"walnut": 0,
"cedar": 0,
"mahogany": 5,
"aspen": 3
},
"isWorth": "cherry",
"points": 2
},
{
"cost": {
"cherry": 3,
"walnut": 0,
"cedar": 5,
"mahogany": 0,
"aspen": 0
},
"isWorth": "mahogany",
"points": 2
},
{
"cost": {
"cherry": 0,
"walnut": 3,
"cedar": 0,
"mahogany": 2,
"aspen": 2
},
"isWorth": "cedar",
"points": 1
},
{
"cost": {
"cherry": 0,
"walnut": 0,
"cedar": 0,
"mahogany": 0,
"aspen": 5
},
"isWorth": "mahogany",
"points": 2
},
{
"cost": {
"cherry": 0,
"walnut": 0,
"cedar": 5,
"mahogany": 0,
"aspen": 0
},
"isWorth": "cedar",
"points": 2
},
{
"cost": {
"cherry": 0,
"walnut": 0,
"cedar": 0,
"mahogany": 5,
"aspen": 0
},
"isWorth": "cherry",
"points": 2
},
{
"cost": {
"cherry": 5,
"walnut": 0,
"cedar": 0,
"mahogany": 0,
"aspen": 0
},
"isWorth": "aspen",
"points": 2
},
{
"cost": {
"cherry": 0,
"walnut": 5,
"cedar": 3,
"mahogany": 0,
"aspen": 0
},
"isWorth": "cedar",
"points": 2
},
{
"cost": {
"cherry": 5,
"walnut": 0,
"cedar": 0,
"mahogany": 3,
"aspen": 0
},
"isWorth": "aspen",
"points": 2
},
{
"cost": {
"cherry": 0,
"walnut": 5,
"cedar": 0,
"mahogany": 0,
"aspen": 0
},
"isWorth": "walnut",
"points": 2
},
{
"cost": {
"cherry": 3,
"walnut": 3,
"cedar": 0,
"mahogany": 0,
"aspen": 2
},
"isWorth": "aspen",
"points": 1
},
{
"cost": {
"cherry": 2,
"walnut": 1,
"cedar": 4,
"mahogany": 0,
"aspen": 0
},
"isWorth": "mahogany",
"points": 2
},
{
"cost": {
"cherry": 1,
"walnut": 0,
"cedar": 0,
"mahogany": 4,
"aspen": 2
},
"isWorth": "walnut",
"points": 2
},
{
"cost": {
"cherry": 0,
"walnut": 0,
"cedar": 6,
"mahogany": 0,
"aspen": 0
},
"isWorth": "cedar",
"points": 3
},
{
"cost": {
"cherry": 0,
"walnut": 2,
"cedar": 0,
"mahogany": 1,
"aspen": 4
},
"isWorth": "cedar",
"points": 2
},
{
"cost": {
"cherry": 0,
"walnut": 0,
"cedar": 0,
"mahogany": 0,
"aspen": 6
},
"isWorth": "aspen",
"points": 3
},
{
"cost": {
"cherry": 0,
"walnut": 4,
"cedar": 2,
"mahogany": 0,
"aspen": 1
},
"isWorth": "cherry",
"points": 2
},
{
"cost": {
"cherry": 0,
"walnut": 2,
"cedar": 2,
"mahogany": 0,
"aspen": 3
},
"isWorth": "mahogany",
"points": 1
},
{
"cost": {
"cherry": 0,
"walnut": 0,
"cedar": 3,
"mahogany": 2,
"aspen": 3
},
"isWorth": "mahogany",
"points": 1
},
{
"cost": {
"cherry": 0,
"walnut": 0,
"cedar": 0,
"mahogany": 6,
"aspen": 0
},
"isWorth": "mahogany",
"points": 3
},
{
"cost": {
"cherry": 2,
"walnut": 0,
"cedar": 0,
"mahogany": 3,
"aspen": 2
},
"isWorth": "cherry",
"points": 1
},
{
"cost": {
"cherry": 4,
"walnut": 0,
"cedar": 1,
"mahogany": 2,
"aspen": 0
},
"isWorth": "aspen",
"points": 2
},
{
"cost": {
"cherry": 3,
"walnut": 0,
"cedar": 2,
"mahogany": 0,
"aspen": 3
},
"isWorth": "cedar",
"points": 1
},
{
"cost": {
"cherry": 2,
"walnut": 0,
"cedar": 3,
"mahogany": 2,
"aspen": 0
},
"isWorth": "aspen",
"points": 1
},
{
"cost": {
"cherry": 2,
"walnut": 3,
"cedar": 0,
"mahogany": 3,
"aspen": 0
},
"isWorth": "cherry",
"points": 1
},
{
"cost": {
"cherry": 3,
"walnut": 2,
"cedar": 2,
"mahogany": 0,
"aspen": 0
},
"isWorth": "walnut",
"points": 1
},
{
"cost": {
"cherry": 6,
"walnut": 0,
"cedar": 0,
"mahogany": 0,
"aspen": 0
},
"isWorth": "cherry",
"points": 3
},
{
"cost": {
"cherry": 0,
"walnut": 6,
"cedar": 0,
"mahogany": 0,
"aspen": 0
},
"isWorth": "walnut",
"points": 3
},
{
"cost": {
"cherry": 0,
"walnut": 3,
"cedar": 0,
"mahogany": 0,
"aspen": 5
},
"isWorth": "walnut",
"points": 2
},
{
"cost": {
"cherry": 0,
"walnut": 2,
"cedar": 3,
"mahogany": 3,
"aspen": 0
},
"isWorth": "walnut",
"points": 1
}
],
"tierThree": [
{
"cost": {
"cherry": 0,
"walnut": 0,
"cedar": 7,
"mahogany": 0,
"aspen": 0
},
"isWorth": "cherry",
"points": 4
},
{
"cost": {
"cherry": 0,
"walnut": 0,
"cedar": 0,
"mahogany": 7,
"aspen": 0
},
"isWorth": "aspen",
"points": 4
},
{
"cost": {
"cherry": 3,
"walnut": 0,
"cedar": 0,
"mahogany": 6,
"aspen": 3
},
"isWorth": "aspen",
"points": 4
},
{
"cost": {
"cherry": 3,
"walnut": 3,
"cedar": 6,
"mahogany": 0,
"aspen": 0
},
"isWorth": "cedar",
"points": 4
},
{
"cost": {
"cherry": 7,
"walnut": 0,
"cedar": 0,
"mahogany": 0,
"aspen": 0
},
"isWorth": "mahogany",
"points": 4
},
{
"cost": {
"cherry": 0,
"walnut": 3,
"cedar": 0,
"mahogany": 3,
"aspen": 6
},
"isWorth": "walnut",
"points": 4
},
{
"cost": {
"cherry": 6,
"walnut": 0,
"cedar": 3,
"mahogany": 3,
"aspen": 0
},
"isWorth": "mahogany",
"points": 4
},
{
"cost": {
"cherry": 0,
"walnut": 0,
"cedar": 0,
"mahogany": 0,
"aspen": 7
},
"isWorth": "walnut",
"points": 4
},
{
"cost": {
"cherry": 0,
"walnut": 7,
"cedar": 0,
"mahogany": 0,
"aspen": 0
},
"isWorth": "cedar",
"points": 4
},
{
"cost": {
"cherry": 0,
"walnut": 6,
"cedar": 3,
"mahogany": 0,
"aspen": 3
},
"isWorth": "cedar",
"points": 4
},
{
"cost": {
"cherry": 0,
"walnut": 5,
"cedar": 3,
"mahogany": 3,
"aspen": 3
},
"isWorth": "cherry",
"points": 3
},
{
"cost": {
"cherry": 3,
"walnut": 3,
"cedar": 0,
"mahogany": 3,
"aspen": 5
},
"isWorth": "cedar",
"points": 3
},
{
"cost": {
"cherry": 5,
"walnut": 3,
"cedar": 3,
"mahogany": 3,
"aspen": 0
},
"isWorth": "aspen",
"points": 3
},
{
"cost": {
"cherry": 3,
"walnut": 3,
"cedar": 5,
"mahogany": 0,
"aspen": 3
},
"isWorth": "mahogany",
"points": 3
},
{
"cost": {
"cherry": 3,
"walnut": 0,
"cedar": 3,
"mahogany": 5,
"aspen": 3
},
"isWorth": "walnut",
"points": 3
},
{
"cost": {
"cherry": 0,
"walnut": 3,
"cedar": 0,
"mahogany": 0,
"aspen": 7
},
"isWorth": "walnut",
"points": 5
},
{
"cost": {
"cherry": 0,
"walnut": 0,
"cedar": 0,
"mahogany": 7,
"aspen": 3
},
"isWorth": "aspen",
"points": 5
},
{
"cost": {
"cherry": 3,
"walnut": 0,
"cedar": 7,
"mahogany": 0,
"aspen": 0
},
"isWorth": "cherry",
"points": 5
},
{
"cost": {
"cherry": 0,
"walnut": 7,
"cedar": 3,
"mahogany": 0,
"aspen": 0
},
"isWorth": "cedar",
"points": 5
},
{
"cost": {
"cherry": 7,
"walnut": 0,
"cedar": 0,
"mahogany": 3,
"aspen": 0
},
"isWorth": "mahogany",
"points": 5
}
]
}

View File

@@ -0,0 +1,15 @@
cedar = emerald
aspen = diamond
cherry = ruby
walnut = sapphire
mahogany = onyx
resin = gold
tokens => card worth
aspen (diamond) => cherry (ruby)
walnut (sapphire) => mahogany (onyx)
cedar (emerald) => aspen (diamond)
mahogany (onyx) => cedar (emerald)
cherry (ruby) => walnut (sapphire)

View File

@@ -0,0 +1,74 @@
{
"spirits": [
{
"cherry": 0,
"walnut": 4,
"cedar": 4,
"mahogany": 0,
"aspen": 0
},
{
"cherry": 0,
"walnut": 3,
"cedar": 0,
"mahogany": 3,
"aspen": 3
},
{
"cherry": 3,
"walnut": 0,
"cedar": 3,
"mahogany": 3,
"aspen": 0
},
{
"cherry": 4,
"walnut": 0,
"cedar": 0,
"mahogany": 4,
"aspen": 0
},
{
"cherry": 0,
"walnut": 0,
"cedar": 0,
"mahogany": 4,
"aspen": 4
},
{
"cherry": 3,
"walnut": 3,
"cedar": 3,
"mahogany": 0,
"aspen": 0
},
{
"cherry": 0,
"walnut": 3,
"cedar": 3,
"mahogany": 0,
"aspen": 3
},
{
"cherry": 3,
"walnut": 0,
"cedar": 0,
"mahogany": 3,
"aspen": 3
},
{
"cherry": 4,
"walnut": 0,
"cedar": 4,
"mahogany": 0,
"aspen": 0
},
{
"cherry": 0,
"walnut": 4,
"cedar": 0,
"mahogany": 0,
"aspen": 4
}
]
}

16
client/src/styles/App.css Normal file
View File

@@ -0,0 +1,16 @@
.App {
background-color: purple;
height: 175vh;
text-align: center;
display: flex;
flex-direction: column;
align-items: center;
}
.gameboard {
margin-top: 5rem;
display: flex;
flex-direction: column;
width: 95vw;
height: 75vh;
}

View File

@@ -0,0 +1,80 @@
// universal card style
.card {
display: flex;
flex-direction: column;
border: 1px solid black;
width: 15vw;
height: 30vh;
// styling for face-up (in-play) cards
.card-row {
display: inline-flex;
flex-direction: row;
justify-content: space-between;
padding: 0.7rem;
height: 50%;
.tier {
display: inline-block;
height: 2rem;
width: 2rem;
border-radius: 50%;
&-3 {
background-color: blue;
}
&-2 {
background-color: yellow;
}
&-1 {
background-color: green;
}
}
}
.bottom-row {
align-items: flex-end;
}
}
// style for individual card "suits"
.cedar {
background-color: limegreen;
}
.mahogany {
background-color: rgb(143, 75, 75);
color: white;
}
.aspen {
background-color: wheat;
}
.walnut {
background-color: rgb(79, 28, 28);
color: white;
}
.cherry {
background-color: brown;
}
// for first-row deck cards
.deck-card {
&-1 {
background-color: green;
}
&-2 {
background-color: yellow;
}
&-3 {
background-color: blue;
}
}
.tier-dot {
display: inline-flex;
background-color: white;
border: 2px solid black;
height: 1.5rem;
width: 1.5rem;
margin: 0.25rem;
border-radius: 50%;
}

View File

@@ -0,0 +1,20 @@
.gameboard-title {
text-decoration: none;
color: white;
font-size: 2rem;
font-weight: bold;
}
.gameboard-row {
display: flex;
flex-flow: row wrap;
width: 90vw;
justify-content: center;
}
.section-border {
display: block;
background-color: black;
width: 100%;
height: 2rem;
}

View File

@@ -0,0 +1,14 @@
import { Context } from '../store/Store';
import { render, screen } from '@testing-library/react';
import { renderHook } from '@testing-library/react-hooks';
import { useContext } from 'react';
describe('card deck', () => {
describe('tier one deck', () => {
it('has 30 cards', () => {
const { theThing } = renderHook(useContext(Context));
let expected = 30;
expect(expected).toBe(30);
})
})
})

27
package-lock.json generated Normal file
View File

@@ -0,0 +1,27 @@
{
"name": "splinter",
"lockfileVersion": 2,
"requires": true,
"packages": {
"": {
"dependencies": {
"uuid": "^8.3.2"
}
},
"node_modules/uuid": {
"version": "8.3.2",
"resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz",
"integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==",
"bin": {
"uuid": "dist/bin/uuid"
}
}
},
"dependencies": {
"uuid": {
"version": "8.3.2",
"resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz",
"integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg=="
}
}
}

5
package.json Normal file
View File

@@ -0,0 +1,5 @@
{
"dependencies": {
"uuid": "^8.3.2"
}
}