Browse Source

Updates type safety

main
Eric Amodio 4 years ago
parent
commit
87afd3bfcf
1 changed files with 19 additions and 11 deletions
  1. +19
    -11
      src/webviews/apps/shared/snow.ts

+ 19
- 11
src/webviews/apps/shared/snow.ts View File

@ -38,21 +38,23 @@ class Snowflake {
} }
export class Snow { export class Snow {
private readonly _canvas: any;
private readonly _ctx: any;
private readonly _canvas: HTMLCanvasElement | undefined;
private readonly _ctx: CanvasRenderingContext2D | undefined;
private _height: number = 0; private _height: number = 0;
private _width: number = 0; private _width: number = 0;
private readonly _snowflakes: Snowflake[] = []; private readonly _snowflakes: Snowflake[] = [];
private readonly _clearBound: any;
private readonly _updateBound: any;
private readonly _clearBound: () => void;
private readonly _updateBound: () => void;
constructor(public snowing: boolean = true) { constructor(public snowing: boolean = true) {
this._clearBound = this.clear.bind(this); this._clearBound = this.clear.bind(this);
this._updateBound = this.update.bind(this); this._updateBound = this.update.bind(this);
this._canvas = document.querySelector('canvas.snow');
this._ctx = this._canvas.getContext('2d');
this._canvas = document.querySelector<HTMLCanvasElement>('canvas.snow') ?? undefined;
this._ctx = this._canvas?.getContext('2d') ?? undefined;
if (this._ctx == null) return;
const trigger = document.querySelector('.snow__trigger'); const trigger = document.querySelector('.snow__trigger');
if (trigger != null) { if (trigger != null) {
@ -65,7 +67,7 @@ export class Snow {
this.onToggle(snowing); this.onToggle(snowing);
} }
onToggle(snowing: boolean) {
onToggle(snowing: boolean): void {
this.snowing = snowing; this.snowing = snowing;
document.body.classList.toggle('snowing', this.snowing); document.body.classList.toggle('snowing', this.snowing);
@ -75,19 +77,23 @@ export class Snow {
} }
} }
onResize() {
onResize(): void {
if (this._canvas == null) return;
this._height = window.innerHeight; this._height = window.innerHeight;
this._width = window.innerWidth; this._width = window.innerWidth;
this._canvas.width = this._width; this._canvas.width = this._width;
this._canvas.height = this._height; this._canvas.height = this._height;
} }
clear() {
clear(): void {
if (this._canvas == null || this._ctx == null) return;
this._ctx.clearRect(0, 0, this._canvas.width, this._canvas.height); this._ctx.clearRect(0, 0, this._canvas.width, this._canvas.height);
this._snowflakes.length = 0; this._snowflakes.length = 0;
} }
createSnowflakes() {
createSnowflakes() class="o">: void {
const flakes = window.innerWidth / 4; const flakes = window.innerWidth / 4;
for (let i = 0; i < flakes; i++) { for (let i = 0; i < flakes; i++) {
@ -95,7 +101,9 @@ export class Snow {
} }
} }
update() {
update(): void {
if (this._ctx == null) return;
this._ctx.clearRect(0, 0, this._width, this._height); this._ctx.clearRect(0, 0, this._width, this._height);
const color = document.body.classList.contains('vscode-light') ? '#424242' : '#fff'; const color = document.body.classList.contains('vscode-light') ? '#424242' : '#fff';

Loading…
Cancel
Save