Angular2 Card Games

Angular2 experimentation and technology demo

Live Demo

Angular CLI

This project was generated with Angular CLI version 7.3.8.

git clone git@github.com:JamesMcGuigan/angular2-card-games.git
npm install; npm prune;
npm run hmr           # run in development mode with HMR:  http://localhost:4200  
npm run build         # create production build in ./dist/
npm run http-server   # node http-server for local production build: http://localhost:8080
npm run deploy:aws    # deploy to Amazon S3 bucket

Technology Features

Angular HMR

NgRX Store

Implementation of NgRX store with actions, selectors, reducers and state typing

Angular2 component rendering from NgRX store

One Card Draw

HashLocationStrategy

Permits using a single HTTP URL for hosting on AWS S3

./src/app/app.module.ts

import { CommonModule, HashLocationStrategy, LocationStrategy } from '@angular/common';
@NgModule({
  providers:    [
    { provide: LocationStrategy, useClass: HashLocationStrategy }  // OR: app-routing.module.ts: RouterModule.forRoot(routes, { useHash: true }),
  ],
})

Unified Angular2 Routing and Menu Component

Deck Of Cards Demo

./angular.json

// ES5 modules via Global Namespace Imports
projects.angular2-card-games.architect.build.scripts = [ 
  'node_modules/deck-of-cards/dist/deck.js' 
]

// Export image assets in node_modules to production ./dist/ build
projects.angular2-card-games.architect.build.assets": [
  "src/favicon.ico",
  "src/assets",
  {
    "glob": "**/*",
    "input": "./node_modules/cardsJS/cards/",
    "output": "./node_modules/cardsJS/cards/"
  }
],

Typescript declaration for Global Namespace Imports

./src/app/pages/page-deck-of-cards/page-deck-of-cards.component.ts

declare var Deck: any;  // Typescript definition for global namespace import

jQuery DOM manipulation

./src/app/pages/page-deck-of-cards/page-deck-of-cards.component.ts

this.element = {
  deck: $(this.el.nativeElement).find('.app-page-deck-of-cards--deck'),
};

TODO

Technology

Game Logic

  • allow a configurable number of players
  • calculate probabilities of winning
  • round-robin bet/raise cycle
  • AI strategies (calling machine, bet above X)
  • implement five-card draw
  • implement texas-holdem poker game
  • implement starting hands probability table
  • monty-carlo simulation

Comparison With React

Been playing around with Angular2 this week, especially to compare it with the React tech stack.

Things I like:

  • Very quick to setup with Angular CLI bootstrapping
  • Batteries included full application framework
  • Typescript for static typing + IDE linting/autocomplete
  • CSS is automatically scoped to the component
  • Angular Schematics for writing boilerplate
  • Optimised AOT (Ahead of Time) production compiling

Common Addon Features

  • NgRX for Redux style store
  • HMR (Hot Module Reloading)
  • URL Routing Module

Things I dislike:

  • Angular2 templates are clunky compared to JSX
  • NgRX components require using RxJS async observables
  • Two-way databinding over pure functional rendering

I can see the advantage of using Angular2 as a single standardized framework for enterprise teams, rather than using a hodge-podge of custom-configured third-party libraries. I do like their framework from a core infrastructure perspective, as it's the sort of thing I would design, so lots of ideas to borrow. However, I do miss the beauty and simplicity of pure-javascript JSX for writing pure functional components, and this alone may be the killer feature of React. Now if only I could get Typescript working with React.

View model rendering differences

The React model is to use a virtual DOM.

Your component has a render() method, a pure-function that renders the current HTML. The Virtual DOM then diffs this against the previous rendering and computes an optimized set of javascript DOM operations to edit the existing HTML. This extra layer of abstraction also allows things like React Native to create non-browser interfaces for iOS/Android/Windows.

The Angular method is template compiling

Your component uses a text HTML template. Some application metadata attributes such as ngIf, ngForEach may leak into the browser visible DOM. The Angular reads the HTML template at compile-time, renders the HTML to the DOM and injects javascript event handlers into the DOM to handle one-way and two-way data bindings.

Runtime performance of the two methods may be comparable, especially given that Angular has an optimised Ahead Of Time compiler flag.