ngx-shot-chart
v0.0.5
Published
An Angular component to create basketball shot charts in real time
Downloads
10
Readme
NgxShotChart 🏀
A simple way to create shotcharts in real time with Angular and d3.js.
Installation
npm install ngx-shot-chart d3 @types/d3
Basic functionality
This lib exposes a NgxShotChartComponent
that renders a shot chart and a NgxShotChartService
with primitives to manipulate symbols in the chart.
The component
- Only emmits the mutually esclusive
ChartClicked
andSymbolClicked
events - Symbols can be any d3.symbolType
- Court and symbols default fill collor is the current text color
- ⛹️ Pre-configured with NBA, FIBA and NCAA court sizes
Usage:
<ngx-shot-chart league='nba' (ChartClicked)="handleChartClicked($event)" (SymbolClicked)="handleSymbolClicked($event)"></ngx-shot-chart>
The service
Exposes a crud interface for shots, methods to draw and clear the court and symbols, and utilities.
Usage:
import { ShotChartService } from 'ngx-shot-chart';
constructor(private shotChartService: ShotChartService) {}
// Add a shot to the chart whenever it is clicked 🪣
handleChartClick(event: ChartClickedEvent) {
this.chart.AddShot(event, d3.symbolCircle);
}
// Remove a shot from the chart whenever the symbol is clicked 🗑️
handleSymbolClick(event: SymbolClickEvent) {
this.chart.RemoveShot(event.id);
}