import React, { useState, useCallback } from "react";
import "./Trade.css";
import { getPlayerName } from './Common.js';
import PlayerColor from './PlayerColor.js';
import Paper from '@material-ui/core/Paper';
import Button from '@material-ui/core/Button';
import Resource from './Resource.js';
const ResourceCounter = ({type, count, onCount, max}) => {
count = count ? count : 0;
const plusClicked = (event) => {
if (max === undefined || max > count) {
if (onCount) {
onCount(type, count+1);
}
}
};
const minusClicked = (event) => {
if (count > 0) {
if (onCount) {
onCount(type, count-1);
}
}
};
return (
{count}
);
};
const Trade = ({table}) => {
const [giveLine, setGiveLine] = useState('nothing');
const [getLine, setGetLine] = useState('nothing');
const [gives, setGives] = useState([]);
const [gets, setGets] = useState([]);
const giveCount = useCallback((type, count) => {
gives[type] = count;
if (!count) {
delete gives[type];
}
setGives(gives);
const items = [];
for (let key in gives) {
items.push(`${gives[key]} ${key}`);
}
if (items.length === 0) {
setGiveLine('nothing');
} else {
setGiveLine(items.join(', '));
}
}, [setGiveLine, setGives, gives]);
const getCount = useCallback((type, count) => {
gets[type] = count;
if (!count) {
delete gets[type];
}
setGets(gets);
const items = [];
for (let key in gets) {
items.push(`${gets[key]} ${key}`);
}
if (items.length === 0) {
setGetLine('nothing');
} else {
setGetLine(items.join(', '));
}
}, [setGetLine, setGets, gets]);
const agreeClicked = useCallback((offer) => {
const trade = {
gives: offer.gets.slice(),
gets: offer.gives.slice()
};
trade.gives.forEach(give => giveCount(give.type, give.count));
trade.gets.forEach(get => getCount(get.type, get.count));
table.offerTrade(trade);
let tmp = {};
trade.gives.forEach(give => {
tmp[give.type] = give.count;
});
setGives(tmp);
tmp = {};
trade.gets.forEach(get => {
tmp[get.type] = get.count;
});
setGets(tmp);
}, [giveCount, getCount, setGives, setGets, table]);
if (!table.game) {
return (<>>);
}
const game = table.game;
const isTurn = (table.game.turn && table.game.turn.color === table.game.color) ? true : false;
const offerClicked = (event) => {
const trade = {
gives: [],
gets: []
};
for (let key in gives) {
trade.gives.push({type: key, count: gives[key]});
}
for (let key in gets) {
trade.gets.push({type: key, count: gets[key]});
}
table.offerTrade(trade);
}
const acceptClicked = (offer) => {
table.acceptTrade(offer);
};
const cancelClicked = (event) => {
table.cancelTrading();
}
/* Non-current player has rejected the active player's
* bid */
const rejectClicked = (trade) => {
table.rejectTrade(trade);
}
let players = [];
for (let color in table.game.players) {
const item = table.game.players[color],
name = getPlayerName(table.game.sessions, color);
if (name && table.game.name !== name) {
players.push({
name: name,
color: color,
valid: false,
gets: item.gets ? item.gets : [],
gives: item.gives ? item.gives : [],
offerRejected: item.offerRejected ? true : false
});
}
}
players.sort((A, B) => {
return A.name.localeCompare(B.name);
});
if (isTurn && table.game.player && table.game.player.banks) {
table.game.player.banks.forEach(bank => {
const count = (bank === 'bank') ? 3 : 2;
players.push({
name: `The bank`,
color: undefined,
gives: [ { count: 1, type: '*' } ],
gets: [ { count: count, type: bank } ],
valid: false
});
});
players.push({
name: `The bank`,
color: undefined,
gives: [ { count: 1, type: '*' } ],
gets: [ { count: 4, type: 'bank' } ],
valid: false
});
}
const player = (table.game && table.game.player) ? table.game.player : undefined;
if (!player) {
return <>>;
}
let canAccept = false;
if (table.game.turn.offer) {
players.forEach(trade => {
trade.valid = trade.gets.length
&& trade.gives.length
&& trade.gets.length === game.turn.offer.gives.length
&& trade.gives.length === game.turn.offer.gets.length;
if (!trade.valid) {
return;
}
trade.gets.forEach(get => {
if (!trade.valid) {
return;
}
if (get.type !== 'bank') {
const offer = table.game.turn.offer.gives.find(give => give.type === get.type);
trade.valid = offer && (offer.count === get.count);
} else {
/* Doesn't matter what the resource type is so long as there
* are enough of the one kind */
trade.valid = table.game.turn.offer.gives[0].count === get.count;
}
});
if (!trade.valid) {
return;
}
trade.gives.forEach(give => {
if (!trade.valid) {
return;
}
if (give.type !== '*') {
const offer = table.game.turn.offer.gets.find(get => give.type === get.type);
trade.valid = offer && (offer.count === give.count);
} else {
/* Doesn't matter what the resource type is so long as there
* are enough of the one kind */
trade.valid = table.game.turn.offer.gets[0].count === give.count;
}
})
});
canAccept = true;
table.game.turn.offer.gets.forEach(item => {
if (!canAccept) {
canAccept = (item.type in game.player);
}
if (!canAccept) {
return;
}
canAccept = (game.player[item.type] >= item.count);
});
}
players = players.map((item, index) => {
if (item.offerRejected) {
return
{item.name}
has rejected your offer.
;
}
const gets = item.gets.map(get =>
`${get.count} ${(get.type === 'bank') ? 'of any one resource' : get.type}`)
.join(', '),
gives = item.gives.map(give =>
`${give.count} ${(give.type === '*') ? 'of any resource' : give.type}`)
.join(', ');
return (
{item.name}
{ gets !== '' && gives !== '' &&
wants {gets} and will give {gives}.
}
{ (gets === '' || gives === '') &&
has not submitted a trade offer.
}
{ isTurn &&
}
{ !isTurn && item.color === table.game.turn.color && <>
> }
);
});
return (
Trading negotiations {isTurn ? '' : `with ${table.game.turn.name}`}
{ players }
{ !player.haveResources && You have no resources to participate in this trade. }
{ player.haveResources &&
You want to receive {getLine}:
You are willing to give {giveLine}:
{ player.brick > 0 && }
{ player.wood > 0 && }
{ player.wheat > 0 && }
{ player.sheep > 0 && }
{ player.stone > 0 && }
}
{ isTurn && }
);
};
export default Trade;