X-Git-Url: https://git.cworth.org/git?a=blobdiff_plain;ds=sidebyside;f=empathy%2Fempathy.jsx;h=4ef6807fef559834be1fed0be1a6f9cb2f2ed889;hb=db513b3fa26652fd2cf42d727604df3ed2ad6002;hp=001dcd5eeeb5ac3f943d368f971f8a78d19981d3;hpb=49a7e9338a8160363ede955ae0d036abc360a359;p=lmno.games diff --git a/empathy/empathy.jsx b/empathy/empathy.jsx index 001dcd5..4ef6807 100644 --- a/empathy/empathy.jsx +++ b/empathy/empathy.jsx @@ -437,8 +437,28 @@ const LetsPlay = React.memo(props => { const max_votes = props.prompts.reduce( (max_so_far, v) => Math.max(max_so_far, v.votes.length), 0); - if (max_votes < quorum) - return null; + if (max_votes < quorum) { + let text = `Before we play, we should collect a bit + more information about what category would + be interesting for this group. So, either + type a new category option above, or else`; + if (props.prompts.length) { + if (props.prompts.length > 1) + text += " vote on some of the categories below."; + else + text += " vote on the category below."; + } else { + text += " wait for others to submit, and then vote on them below."; + } + + return ( +
+

+ {text} +

+
+ ); + } const candidates = props.prompts.filter(p => p.votes.length >= max_votes); const index = Math.floor(Math.random() * candidates.length); @@ -675,11 +695,16 @@ class Ambiguities extends React.PureComponent {

Judging Answers

- Click on each pair of answers that should be scored as equivalent, - (and click any word twice to split it out from a group). Remember, + Click/tap on each pair of answers that should be scored as equivalent, + (or click a word twice to split it out from a group). Remember, what goes around comes around, so it's best to be generous when judging.

+

+ Also, for an especially fun or witty answer, you can give kudos + by clicking the star on the right. You may only do this for one + word/group. +

{this.props.prompt.prompt}

{this.state.word_sets.map(set => { return ( @@ -705,9 +730,15 @@ class Ambiguities extends React.PureComponent { } onClick={(event) => { event.stopPropagation(); - this.setState({ - starred: set - }); + if (this.state.starred === set) { + this.setState({ + starred: null + }); + } else { + this.setState({ + starred: set + }); + } }} > {this.state.starred === set ? @@ -1225,11 +1256,15 @@ class Game extends React.PureComponent { if (score.score === state.active_prompt.items) { quirkster = Quirkster!; } + let kudos_slam = null; + if (score.kudos > 0 && score.kudos >= players_total - 1) { + kudos_slam = Kudos Slam!; + } return (
  • {score.players.join("/")}: {score.score} {score.kudos ? `, ${'★'.repeat(score.kudos)}` : ""} - {perfect} {quirkster} + {' '}{perfect} {quirkster} {kudos_slam}
  • ); })} @@ -1237,11 +1272,20 @@ class Game extends React.PureComponent {

    Words submitted