Categories
BLOG

keno stat ma

Keno stat ma

Mass Keno Tracker

This is a single page real time data visualization web app for the Massachusett’s Lottery’s Keno game built in javascript using Backbone and Require. It uses data from the Massachusett’s Lottery’s daily Keno data object which I’m serving as JSONp data from an S3 bucket to prevent undue load to the lottery’s website.

By default the app shows data from all of the day’s Keno games. However, using the text box in the heading area you can adjust it to poll a subset of games. As new games are drawn the updated data is loaded into the browser.

“Hot” and “cold” numbers are calculated based on the number of games being polled and indicated with blue and red borders.

Draw frequency is also inidicated with opacity. The darker the background of a number the more often it has been drawn. If polling a small number of games (

This project is a pretty straightforward Backbone and Require single page web app. Basically a bunch of Backbone views tied together via a single “app” view that manages the eventing. Collections and models all provide a hefty dose of helper functions to make working through the data as clean as possible.

Optimized files are generated via grunt. To build new optimized files for this project simply clone it, run npm install to setup grunt, and issue the grunt command. The default task lints the code and builds with the r.js optimizer.

If you’d like to hack around on this code, it would probably be easier to do so without having to optimize everytime you make a change. Just comment out the optimize block and uncomment the require block in index.html .

Front end chores in no particular order:

  • Fix UI
  • Allow lookup of a specific keno draw by game number
  • Maybe support keno bonus calculations if a good UI can be worked out
  • While this works on mobile, the ratio is all off for most screen sizes.

The Server Side

There is a very simple backend responsible for writing JSONp data to S3 so the app can get realtime game data. The code for this backend exists in the server directory.

The app is configured to read from my S3 bucket by default, so using the app does not require you to set up your own server. If, however, you find yourself interested in giving it a shot, here’s what’s going on.

I have a m1.small server booted in EC2 configured to run the realtimeKenoService via cron every minute.

The server side code has been pulled into its own repository and is currently deployed on Heroku. The scheduling is accomplished with Heroku Scheduler instead of CRON. As a result the data coming from S3 is less than realtime, but Heroku doesn’t support CRON and I’m too cheap to keep an EC2 server running for this.

About

Realtime visualization of the Massachusett’s Lottery’s Keno game built in JS with Backbone and Require.

Realtime visualization of the Massachusett's Lottery's Keno game built in JS with Backbone and Require. – MattSurabian/mass-keno-tracker

Keno

Date of birth/Age: Sep 10, 1989 (31)

Place of birth: Salvador

Position: Left Winger

Contract expires: Dec 31, 2023

Last update: Sep 9, 2020

Stats

This page contains information about a player’s detailed stats. In the info box, you can filter by period, club, type of league and competition. The “Detailed stats” tab shows a player’s total appearances, goals, cards and cumulative minutes of play for each competition, and indicates the season in which it occurred.

Player stats of Keno (Atlético Mineiro) ➤ Goals ➤ Assists ➤ Matches played ➤ All performance data