-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathscript.js
More file actions
114 lines (89 loc) · 2.62 KB
/
script.js
File metadata and controls
114 lines (89 loc) · 2.62 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
let Typr = () => {
let $listener;
let _view;
let _starfield;
let _particle;
let _pong;
let _clock;
let init = () => {
$listener = document.querySelector(Config.keyPressElement);
$listener.addEventListener('keypress', onKeyPressed);
$listener.addEventListener('keydown', onKeyDown);
window.addEventListener('resize', onResize);
_starfield = Starfield();
_particle = Particle();
_pong = Pong();
_clock = Clock();
_view = View(_starfield, _particle);
};
let onKeyPressed = (event) => {
var keyCode = event.which;
// ignore backspace and enter
if ( (keyCode == 8) || (keyCode == 13)) {
event.preventDefault();
} else {
var character = String.fromCharCode( keyCode );
onAddCharacter(String.fromCharCode(keyCode), event);
}
}
let isCapsLock = (event) => {
return event.getModifierState && event.getModifierState( 'CapsLock' );
}
let isScrollLock = (event) => {
return event.getModifierState && event.getModifierState( 'ScrollLock' );
}
let onKeyDown = (event) => {
Config.isScreenShakeEnabled = isCapsLock(event) || isScrollLock(event) || Config.isScreenShakeEnabled;
switch(event.keyCode){
//backspace
case 8:
onDeleteCharacter(event);
break;
//enter
case 13:
onAddLineBreak(event);
break;
//F4 -- change background
case 115:
Config.starfieldSprite = ++Config.starfieldSprite < 3 ? Config.starfieldSprite : 0;
break;
//F6 -- change word replace
case 117:
Config.replaceWords = ++Config.replaceWords <= Config.replaceWordsWith.length ? Config.replaceWords : 0;
_view.onUpdate();
break;
//F7 -- change textcolor
case 118:
Config.textColor = ++Config.textColor < Config.textColorPalette.length ? Config.textColor : 0;
_view.onUpdate();
break;
//F8 -- change font
case 119:
Config.textFont = ++Config.textFont < Config.textFontList.length ? Config.textFont : 0;
_view.onUpdate();
break;
//F9 -- pong
case 120:
Config.isPongEnabled = !Config.isPongEnabled;
break;
}
}
var onResize = () => {
_view.onResize();
_starfield.onResize();
_particle.onResize();
_pong.onResize();
_clock.onResize();
}
var onAddCharacter = (character, event) => {
_view.onAddCharacter(character);
}
var onDeleteCharacter = (event) => {
_view.onDeleteCharacter(event);
}
var onAddLineBreak = (event) => {
_view.onAddLineBreak(event);
}
init();
};
Typr();