diff --git a/README.MD b/README.MD index f352c29..df7185f 100644 --- a/README.MD +++ b/README.MD @@ -246,6 +246,15 @@ Array of timeframes that allows to override options based on local time. See exa } } ``` +#### minimumVotesToAcceptResult +###### Description +Minimum votes per map to accept result. + +Can be used to prevent situation when insignificant number of players decide what map should be next, but most still wants to play map according to rotation. +###### Default +```json +1 +``` ### Example configuration ```json { @@ -278,6 +287,7 @@ Array of timeframes that allows to override options based on local time. See exa "channelID": "112233445566778899", "persistentDataFile": "", "timezone": 2, + "minimumVotesToAcceptResult": 1, "timeFrames": [ { "name": "follow layer rotation list", diff --git a/mapvote.js b/mapvote.js index 32d126b..6fdada8 100644 --- a/mapvote.js +++ b/mapvote.js @@ -170,6 +170,11 @@ export default class MapVote extends DiscordBasePlugin { required: false, description: 'Array of timeframes to override options', default: [] + }, + minimumVotesToAcceptResult: { + required: false, + description: "Minimum votes per map to accept result.", + default: 1 } }; } @@ -301,7 +306,6 @@ export default class MapVote extends DiscordBasePlugin { } } setSeedingMode(isNewGameEvent = false) { - // setTimeout(()=>{this.msgDirect('76561198419229279',"MV\ntest\ntest")},1000) // this.msgBroadcast("[MapVote] Seeding mode active") const baseDataExist = this && this.options && this.server && this.server.players; if (baseDataExist) { @@ -970,15 +974,17 @@ export default class MapVote extends DiscordBasePlugin { let highestScore = -Infinity; for (let choice in this.tallies) { const score = this.tallies[ choice ]; - if (score < highestScore) - continue; - else if (score > highestScore) { - highestScore = score; - ties.length = 0; - ties.push(choice); + if (score >= this.options.minimumVotesToAcceptResult) { + if (score < highestScore) + continue; + else if (score > highestScore) { + highestScore = score; + ties.length = 0; + ties.push(choice); + } + else // equal + ties.push(choice); } - else // equal - ties.push(choice); } return ties.map(i => this.nominations[ i ]);