Merge tag '1.6.6' into develop

1.6.6
This commit is contained in:
ntr 2019-10-27 14:57:43 +11:00
commit 620171f464
9 changed files with 31 additions and 29 deletions

View File

@ -2,7 +2,6 @@
All notable changes to this project will be documented in this file.
This project adheres to [Semantic Versioning](http://semver.org/).
## [1.6.5] - 2019-10-27
# Added
- Offering of draws

View File

@ -1 +1 @@
1.6.5
1.6.6

View File

@ -1,6 +1,6 @@
{
"name": "mnml-client",
"version": "1.6.5",
"version": "1.6.6",
"description": "",
"main": "index.js",
"scripts": {

View File

@ -1,6 +1,6 @@
{
"name": "mnml-client",
"version": "1.6.5",
"version": "1.6.6",
"description": "",
"main": "index.js",
"scripts": {

View File

@ -8,6 +8,7 @@ const addState = connect(
const {
ws,
game,
account,
} = state;
function sendAbandon() {
@ -20,6 +21,7 @@ const addState = connect(
return {
game,
account,
sendAbandon,
sendDraw,
@ -39,6 +41,7 @@ const addState = connect(
function GameCtrlTopBtns(args) {
const {
game,
account,
leave,
sendAbandon,
@ -48,6 +51,9 @@ function GameCtrlTopBtns(args) {
const finished = game && game.phase === 'Finished';
const { abandonState, drawState } = this.state;
const player = game.players.find(p => p.id === account.id);
const drawOffered = player && player.draw_offered;
const abandonStateTrue = e => {
e.stopPropagation();
this.setState({ abandonState: true });
@ -66,10 +72,12 @@ function GameCtrlTopBtns(args) {
const abandonBtn = <button class={abandonClasses} disabled={finished} onClick={abandonAction}>{abandonText}</button>;
const drawClasses = `draw ${drawState ? 'confirming' : ''}`;
const drawText = drawState ? 'Draw' : 'Offer';
const drawClasses = `draw ${drawState || drawOffered ? 'confirming' : ''}`;
const drawText = drawOffered
? 'Offered'
: drawState ? 'Draw' : 'Offer';
const drawAction = drawState ? sendDraw : drawStateTrue;
const drawBtn = <button class={drawClasses} disabled={finished} onClick={drawAction}>{drawText}</button>;
const drawBtn = <button class={drawClasses} disabled={finished || drawOffered} onClick={drawAction}>{drawText}</button>;
return (
<div class="instance-ctrl-btns">

View File

@ -68,6 +68,11 @@ function Scoreboard(args) {
};
const winner = player.score === 'Win';
const chatText = chat
? chat
: player.draw_offered
? 'draw'
: '\u00A0';
if (!isPlayer) {
const nameClass = `name ${player.img ? 'subscriber' : ''}`;
@ -77,7 +82,7 @@ function Scoreboard(args) {
<div class="score">{scoreText()}</div>
<div class={nameClass}>{player.name}</div>
<Img img={player.img} id={player.id} />
<div class="msg">{chat || '\u00A0'}</div>
<div class="msg">{chatText}</div>
</div>
);
}
@ -87,7 +92,7 @@ function Scoreboard(args) {
return (
<div class={boxClass}>
<div class="msg">{chat || '\u00A0'}</div>
<div class="msg">{chatText}</div>
<div class="score">{scoreText()}</div>
<div class={nameClass}>{player.name}</div>
<Img img={player.img} id={player.id} />

View File

@ -1,6 +1,6 @@
{
"name": "mnml-ops",
"version": "1.6.5",
"version": "1.6.6",
"description": "",
"main": "index.js",
"scripts": {

View File

@ -1,6 +1,6 @@
[package]
name = "mnml"
version = "1.6.5"
version = "1.6.6"
authors = ["ntr <ntr@smokestack.io>"]
[dependencies]

View File

@ -335,28 +335,18 @@ impl Instance {
}
fn finish_condition(&mut self) -> bool {
// tennis
for player in self.players.iter() {
if player.score == Score::Win {
self.winner = Some(player.id);
return true;
}
}
// Game defaults to lose otherwise
if self.rounds.len() < 4 {
return false;
}
// both players afk
if self.players.iter().all(|p| p.score == Score::Zero) {
return true;
}
return false;
self.players.iter().any(|p| p.score == Score::Win)
}
pub fn finish(&mut self) -> &mut Instance {
self.phase = InstancePhase::Finished;
for player in self.players.iter() {
if player.score == Score::Win {
self.winner = Some(player.id);
}
}
self
}