
Product
Introducing Webhook Events for Pull Request Scans
Add real-time Socket webhook events to your workflows to automatically receive pull request scan results and security alerts in real time.
♥ ♦ ♣ â™
Thousand card game logic, written in TypeScript.
Visit https://plnkr.co/edit/o73CajJDIuEZWHp1kH0C?p=preview and observe console output
$ npm install -S 1k
import { initializeGame, createCard, Thousand, Game } from '1k';
const thousand: Thousand = initializeGame();
thousand.init();
let result: boolean; // its a result of action, true - action succeed, false otherwise
// registers player with specific name
result = thousand.registerPlayer('adam');
result = thousand.registerPlayer('pic');
// player makes a bid
result = thousand.bid('adam', 120);
// player passes
result = thousand.pass('adam');
// player (adam) shares card (9♥) with opponent (alan)
result = thousand.shareStock('adam', createCard('9♥'), 'alan');
// player declares a bomb
result = thousand.declareBomb('adam');
// player increases his bid
result = thousand.increaseBid('adam', 130);
// player throws a card
result = thousand.throwCard(createCard('A♥'), 'adam');
// get entire game state object
const state: Game = thousand.getState();
console.log(state);
Available phases:
enum Phase {
REGISTERING_PLAYERS_START = 'REGISTERING_PLAYERS_START',
REGISTERING_PLAYERS_IN_PROGRESS = 'REGISTERING_PLAYERS_IN_PROGRESS',
REGISTERING_PLAYERS_FINISHED = 'REGISTERING_PLAYERS_FINISHED',
DEALING_CARDS_START = 'DEALING_CARDS_START',
DEALING_CARDS_IN_PROGRESS = 'DEALING_CARDS_IN_PROGRESS',
DEALING_CARDS_FINISHED = 'DEALING_CARDS_FINISHED',
BIDDING_START = 'BIDDING_START',
BIDDING_IN_PROGRESS = 'BIDDING_IN_PROGRESS',
BIDDING_FINISHED = 'BIDDING_FINISHED',
BATTLE_START = 'BATTLE_START',
TRICK_START = 'TRICK_START',
TRICK_IN_PROGRESS = 'TRICK_IN_PROGRESS',
TRICK_FINISHED = 'TRICK_FINISHED',
FLIP_STOCK = 'FLIP_STOCK',
ASSIGN_STOCK = 'ASSIGN_STOCK',
SHARE_STOCK = 'SHARE_STOCK',
BATTLE_FINISHED = 'BATTLE_FINISHED',
BATTLE_RESULTS_ANNOUNCEMENT = 'BATTLE_RESULTS_ANNOUNCEMENT',
ASSIGN_TRICK_CARDS = 'ASSIGN_TRICK_CARDS',
BOMB_DECLARED = 'BOMB_DECLARED',
GAME_FINISHED = 'GAME_FINISHED'
}
import { initializeGame, createCard, Thousand } from '1k';
const thousand: Thousand = initializeGame();
// called whenever game is updated
thousand.events.addListener('phaseUpdated', next => {
const state: Game = thousand.getState();
console.log('Current phase', state.phase);
console.log('Current state', state);
// after managing state, let the game proceed...
next();
});
// called, when any action made succesfully
thousand.events.addListener('action', action => {
const state: Game = thousand.getState();
console.log('action made succesfully: ', action);
});
FAQs
Thousand Card Game Logic
We found that muib demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Product
Add real-time Socket webhook events to your workflows to automatically receive pull request scan results and security alerts in real time.
Research
The Socket Threat Research Team uncovered malicious NuGet packages typosquatting the popular Nethereum project to steal wallet keys.
Product
A single platform for static analysis, secrets detection, container scanning, and CVE checks—built on trusted open source tools, ready to run out of the box.