Skip to content

Instantly share code, notes, and snippets.

@shahan27
Last active June 26, 2021 05:17
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save shahan27/3bf9a377e847c646bce97002afb14c38 to your computer and use it in GitHub Desktop.
Save shahan27/3bf9a377e847c646bce97002afb14c38 to your computer and use it in GitHub Desktop.
Shoot-em-up game
<div id="game_over" class="state-ui-container">
<div class="console">
<div class="ui-text ui-text--heading">GAME OVER!</div>
<div id="final_score" class="ui-text"></div>
<div class="ui-text">PRESS [ENTER] TO PLAY AGAIN!</div>
<div class="ui-text">PRESS [R] TO GO TO TITLE SCREEN</div>
</div>
</div>
<div id="title" class="state-ui-container">
<div class="console">
<div class="ui-text ui-text--heading">SPACE FORCE: X-ALPHA 2 TURBO</div>
<div class="ui-text">INSTRUCTIONS:</div>
<div class="ui-text">PRESS [ARROW KEYS] TO MOVE!</div>
<div class="ui-text">PRESS [SPACE] TO SHOOT!</div>
<div class="ui-text">PRESS [ENTER] TO PLAY!</div>
<div class="ui-text">PRESS [R] TO COME BACK TO THIS SCREEN</div>
</div>
</div>
<div id="game" class="state-ui-container">
<div class="banner">
<div id="score" class="ui-text">SCORE: 0</div>
<div id="lives" class="ui-text">LIVES: 3</div>
</div>
</div>
var TOP_TURN = false;
var canvas = document.createElement('canvas');
var context = canvas.getContext('2d');
context.globalAlpha = .1;
var fps = 1000 / 60;
var then = Date.now();
var startTime = then;
/**
* Piskel was used to create my sprites.
* It is a free online editor for animated sprites & pixel art
* you should check it out (it's incredible)
* https://www.piskelapp.com/
*/
var speedUpSprite = '';
var powerUpSprite = ''
var bulletSprite = '';
var burnSprite = '';
var popCornSprite = '';
var shipSprite = '';
var explosionSprite = '';
canvas.id = 'viewport';
canvas.width = window.innerWidth*.5;
canvas.height = window.innerHeight*.5;
context.imageSmoothingEnabled = false;
document.getElementsByTagName('body')[0].appendChild(canvas);
WAVE = 1800;
if (TOP_TURN) {
canvas.style.transform = 'scaleX(-1)';
UP = 39;
DOWN = 37;
LEFT = 40;
RIGHT = 38;
SHOOT = 32;
RESET = 82;
START = 13;
} else {
UP = 38;
DOWN = 40;
LEFT = 37;
RIGHT = 39;
SHOOT = 32;
RESET = 82;
START = 13;
}
function State(name, updater, renderer)
{
this.name = name;
this.updater = updater;
this.renderer = renderer;
}
function Intersection() {
}
Intersection.rectanglesIntersect = function(rect1, rect2) {
return (
rect1.x < rect2.x + rect2.width &&
rect1.x + rect1.width > rect2.x &&
rect1.y < rect2.y + rect2.height &&
rect1.height + rect1.y > rect2.y
);
}
function Star(x, y) {
var r = Math.max(50,Math.floor(Math.random()*256));
var g = Math.max(125, Math.floor(Math.random()*256));
var b = Math.max(240, Math.floor(Math.random()*256));
this.x = Math.floor(x);
this.y = Math.floor(y);
var size = Math.floor(Math.random() * Star.MAX_SIZE);
this.width = size;
this.height = size;
this.variance = Math.max(Math.random(), .2);
this.color = 'rgb('+r+', '+g+', '+b+')';
}
Star.SPEED = 5;
Star.MAX_SIZE = 2;
Star.prototype.update = function() {
if (game.overdrive) {
var travel = Star.SPEED*this.variance*6;
this.width = 50;
} else {
var travel = Star.SPEED*this.variance;
this.width = this.height;
}
this.x -= travel;
if(this.x + this.width < 0) {
this.x = canvas.width;
}
}
Game.prototype.updateScore = function() {
document.getElementById('score').innerHTML = 'SCORE: ' + this.score;
}
Game.prototype.updateLives = function() {
document.getElementById('lives').innerHTML = 'LIVES: ' + this.lives;
}
Star.prototype.render = function(context) {
if (game.overdrive) {
context.globalAlpha = .6;
}
context.fillStyle = (game.overdrive) ? 'rgba(125, 135, 255, 1)' : this.color;
context.fillRect(this.x, this.y, this.width, this.height);
context.globalAlpha = 1;
}
function Explosion(x, y) {
this.currentFrame = 0;
this.frames = 12;
this.buffer = 4;
this.currentBuffer = 0;
this.alive = false;
this.img = document.createElement('img');
this.img.src = explosionSprite;
}
Explosion.prototype.reset = function() {
this.currentFrame = 0;
this.frames = 12;
this.buffer = 4;
this.currentBuffer = 0;
this.alive = false;
};
Explosion.prototype.update = function() {
if (!this.alive) {
return;
}
this.x -= Popcorn.SPEED;
if (this.currentBuffer === this.buffer) {
this.currentBuffer = 0;
this.currentFrame++;
if (this.currentFrame === this.frames) {
this.reset();
}
}
this.currentBuffer++;
}
Explosion.prototype.render = function(context) {
if (!this.alive) {
return;
}
context.drawImage(
this.img,
0, this.currentFrame * 32, 32, 32,
this.x-16, this.y-16, 64, 64
);
}
function TitleState(name)
{
State.call(this, name, this.update, this.render);
}
TitleState.prototype = new State();
TitleState.prototype.init = function() {
game.overdrive = true;
context.setTransform(1, 0, 0, 1, 0, 0);
game.showUI('title');
this.entities = [];
this.starField = [];
for (var i = 0; i < 1024; i++) {
this.starField.push(
new Star(
Math.random()*canvas.width,
Math.random()*canvas.height
)
);
}
}
TitleState.prototype.update = function() {
if (inputManager.start) {
game.setState(game.states.game);
game.currentState.init();
}
this.starField.forEach(function(entity) {
entity.update();
})
}
TitleState.prototype.render = function(context) {
context.clearRect(0, 0, canvas.width, canvas.height);
this.starField.forEach(function(entity) {
entity.render(context);
})
}
function GameOverState(name)
{
State.call(this, name, this.update, this.render);
}
GameOverState.prototype = new State();
GameOverState.prototype.init = function() {
context.setTransform(1, 0, 0, 1, 0, 0);
this.timer = 0;
console.log('Game Over');
game.showUI('game_over');
document.querySelector('#final_score').innerHTML = 'FINAL SCORE: ' + game.score;
}
GameOverState.prototype.update = function() {
if (inputManager.start) {
game.setState(game.states.game);
game.currentState.init();
game.reset();
}
this.timer++;
}
GameOverState.prototype.render = function(context) {
for (var i = 0; i < canvas.width; i++) {
context.drawImage(
canvas,
i, 0, 1, canvas.height,
i, Math.sin((i*20*Math.PI/180))*2, 1, canvas.height
);
}
for (var i = 0; i < canvas.height; i++) {
context.drawImage(
canvas,
i, 0, canvas.width, 1,
i, Math.sin((i*12*Math.PI/180))*2, canvas.width, 1
);
}
if (this.timer > 60) {
context.globalAlpha = .3;
}
}
function GameState(name)
{
State.call(this, name, this.update, this.render);
}
GameState.prototype = new State();
GameState.prototype.init = function() {
game.overdrive = true;
this.overdriveTimer = 90;
context.setTransform(1, 0, 0, 1, 0, 0);
game.showUI('game');
this.timer = 0;
this.tier1 = 1 * WAVE;
this.tier2 = 2 * WAVE;
this.tier3 = 3 * WAVE;
this.tier4 = 4 * WAVE;
this.enemyTimerEasy = 120;
this.enemyTimerMedium = 60;
this.enemyTimerHard = 30;
this.enemyTimerNightmare = 5;
this.currentEnemyTimer = this.enemyTimerEasy;
this.powerUpTimer = 1600;
this.starField = [];
for (var i = 0; i < 1024; i++) {
this.starField.push(
new Star(
Math.random()*canvas.width,
Math.random()*canvas.height
)
);
}
this.player = new Player(20, Math.floor(canvas.height * .5), 100, null);
for (var i = 0; i < 256; i++) {
this.player.bulletPool.push(new Bullet(this.player.x + 32, this.player.y + 16, 1, 15));
}
this.enemyList = [];
for (var i = 0; i < 32; i++) {
this.enemyList.push(new Popcorn(canvas.width, Math.random() * (canvas.height - 32)));
}
this.explosions = [];
for (var i = 0; i < 32; i++) {
this.explosions.push(new Explosion(0, 0));
}
this.powerUps = [];
for (var i = 0; i < 32; i++) {
this.powerUps.push(new PowerUp(0, 0));
}
this.entities = [this.player];
this.entities = this.entities.concat(
this.enemyList,
this.explosions,
this.powerUps,
this.player.bulletPool
);
console.log('game initialised');
}
GameState.prototype.deployEnemies = function() {
if (this.timer && (this.timer % this.currentEnemyTimer === 0) ) {
var enemy = this.enemyList.find(function(enemy) {
return !enemy.alive;
});
enemy.reset();
enemy.x = canvas.width;
enemy.alive = true;
enemy.y = Math.max(4, (canvas.height * Math.random()) - 24);
}
}
GameState.prototype.deployPowerUps = function() {
if (this.timer && (this.timer % this.powerUpTimer === 0) ) {
if (Math.random() >= .01) {
var powerup = this.powerUps.find(function(powerup) {
return !powerup.alive;
});
powerup.x = canvas.width;
powerup.alive = true;
powerup.y = (canvas.height * Math.random()) - 16;
}
}
}
GameState.prototype.update = function() {
if (this.timer > this.tier2) {
this.currentEnemyTimer = this.enemyTimerMedium;
}
if (this.timer > this.tier3) {
this.currentEnemyTimer = this.enemyTimerHard;
}
if (this.timer > this.tier4) {
this.currentEnemyTimer = this.enemyTimerNightmare;
}
if (this.overdriveTimer < this.timer) {
game.overdrive = false;
}
this.timer++;
this.deployEnemies();
this.deployPowerUps();
this.entities.forEach(function(entity) {
entity.update();
});
this.player.bulletPool.forEach(function(bullet) {
if (!bullet.alive) {
return;
}
game.currentState.enemyList.forEach(function(enemy) {
if (!enemy.alive) {
return;
}
if (Intersection.rectanglesIntersect(bullet, enemy)) {
enemy.takeDamage(10);
bullet.alive = false;
if (!enemy.alive) {
game.score += enemy.value;
game.updateScore();
enemy.hit = true;
var explosion = game.currentState.explosions.find(notAlive);
explosion.x = enemy.x;
explosion.y = enemy.y;
explosion.alive = true;
}
}
});
});
var player = game.currentState.player;
if (player.alive) {
this.enemyList.forEach(function(enemy) {
if(!enemy.alive) {
return;
}
var playerHitBox = player.getHitBox();
if(Intersection.rectanglesIntersect(enemy, playerHitBox)) {
player.takeDamage(500);
enemy.takeDamage(500);
game.lives--;
game.updateLives();
var explosion = game.currentState.explosions.find(notAlive);
explosion.x = enemy.x;
explosion.y = enemy.y;
explosion.alive = true;
var explosion = game.currentState.explosions.find(notAlive);
explosion.x = player.x;
explosion.y = player.y;
explosion.alive = true;
if (game.lives === 0) {
game.setState(game.states.game_over);
game.currentState.init();
}
}
});
this.powerUps.forEach(function(powerup) {
if (!powerup.alive) {
return;
}
if (Intersection.rectanglesIntersect(powerup, player.getHitBox())) {
player.powerLevel++;
powerup.reset();
game.score += powerup.value;
game.updateScore();
}
});
}
}
notAlive = function(item){
return !item.alive;
}
alive = function(item) {
return alive;
}
GameState.prototype.renderBackground = function(context) {
this.starField.forEach(function(star) {
star.update();
star.render(context);
});
}
GameState.prototype.render = function(context) {
context.fillStyle = '#000';
context.fillRect(0, 0, canvas.width, canvas.height);
context.globalAlpha = 1;
this.renderBackground(context);
this.entities.forEach(
function(entity){
entity.render(context);
}
);
}
function Game()
{
this.reset();
this.states = {};
this.states['game'] = new GameState('game');
this.states['title'] = new TitleState('title');
this.states['game_over'] = new GameOverState('game_over');
this.entities = [];
}
Game.prototype.reset = function() {
this.score = 0;
this.lives = 3;
this.updateScore();
this.updateLives();
}
Game.prototype.setState = function(state) {
this.currentState = state;
}
Game.prototype.showUI = function(name) {
document.querySelectorAll('.state-ui-container').forEach(function(element) {
element.style.display = 'none';
});
document.querySelector('#'+name).style.display = 'flex';
}
function Ship(x, y, width, height, health)
{
this.x = x;
this.y = y;
this.width = width;
this.height = height;
this.health = health;
this.hit = false;
this.alive = true;
this.vx = 0;
this.vy = 0;
}
Ship.prototype.render = function(context) {
context.fillStyle = '#666';
context.fillRect(this.x, this.y, this.width, this.height);
}
Ship.prototype.takeDamage = function(damage) {
this.health -= damage;
if (this.health <= 0) {
this.alive = false;
}
}
function Bullet(x, y, dir, speed) {
this.vx = 0;
this.vy = 0;
this.width = 16;
this.height = 8;
this.x = x;
this.y = y;
this.dir = dir;
this.speed = speed;
this.alive = false;
this.img = document.createElement('img');
this.img.src = bulletSprite;
}
Bullet.prototype.update = function() {
if (!this.alive) {
return;
}
if (this.dir === 1) this.vx = this.speed + (Math.min(game.currentState.player.powerLevel * 2, 20));
if (this.dir === -1) this.vx = this.speed;
this.x += this.vx;
if (this.x > canvas.width) {
this.alive = false;
}
}
Bullet.prototype.render = function(context) {
if (!this.alive) {
return
}
context.drawImage(this.img, 0, 0, 16, 8, this.x, this.y, this.width, this.height);
}
function PowerUp(x, y) {
this.x = x;
this.y = y;
this.timer = Math.random() * 256;
this.currentFrame = 0;
this.currentBuffer = 0;
this.buffer = 4;
this.jump = canvas.height * .5;
this.speed = 3;
this.frames = 7;
this.width = 16;
this.height = 16;
this.img = document.createElement('img');
this.img.src = powerUpSprite;
this.value = 20;
}
PowerUp.prototype.update = function() {
this.vy = Math.cos(this.timer) * this.jump;
this.timer += .03;
this.y = canvas.height * .5 + this.vy;
this.x -= this.speed;
if (this.x + this.width <= 0) {
this.reset();
}
}
PowerUp.prototype.reset = function() {
this.alive = false;
}
PowerUp.prototype.render = function(context) {
if (!this.alive) {
return;
}
if (this.currentBuffer === this.buffer) {
this.currentBuffer = 0;
this.currentFrame ++;
if (this.currentFrame === this.frames) {
this.currentFrame = 0;
}
}
this.currentBuffer++;
context.drawImage(
this.img, 0, this.currentFrame * 16, 16, 16,
this.x, this.y, this.width, this.height
)
}
function Player(x, y, health, weapon)
{
Ship.call(this, x, y, 32, 32, health);
this.burning = false;
this.frame = 0;
this.burnFrame = 0;
this.weapon = weapon;
this.speed = 5;
this.powerLevel = 1;
this.bulletTimer = 5;
this.bulletCoolDown = 5;
this.img = document.createElement('img');
this.burnImg = document.createElement('img');
this.img.src = shipSprite;
this.burnImg.src = burnSprite;
this.bulletPool = [];
this.hitBoxSize = [8, 8];
}
Player.prototype = new Ship();
Player.prototype.getHitBox = function() {
return {
x: this.x + (this.width * .5) - (this.hitBoxSize[0] * .5),
y: this.y + (this.height * .5) - (this.hitBoxSize[1] * .5),
width: this.hitBoxSize[0],
height: this.hitBoxSize[1],
}
}
Player.prototype.update = function() {
if (!this.alive) {
if (inputManager.start) {
game.currentState.init();
}
return;
}
this.vx = 0;
this.vy = 0;
if (inputManager.upPressed) {
this.vy -= this.speed;
}
if (inputManager.downPressed) {
this.vy += this.speed;
}
if (inputManager.rightPressed) {
this.vx += this.speed;
this.burning = true;
} else {
this.burning = false;
}
if (inputManager.leftPressed) {
this.vx -= this.speed;
this.burning = false;
}
if (inputManager.shooting || game.autoShoot) {
if (this.bulletCoolDown === this.bulletTimer) {
this.shoot();
this.bulletTimer = 0;
} else {
this.bulletTimer++;
}
}
this.x += this.vx;
this.y += this.vy;
if (this.x < 0) {
this.x = 0;
}
if (this.y < 0) {
this.y = 0;
}
if (this.x+this.width > canvas.width) {
this.x = canvas.width - this.width;
}
if (this.y+this.height > canvas.height) {
this.y = canvas.height - this.height;
}
}
Player.prototype.shoot = function() {
if (this.powerLevel === 1) {
var bullet = this.bulletPool.find(notAlive);
if (!bullet) {
return;
}
bullet.x = this.x + this.width - bullet.width;
bullet.y = (this.y + (this.height * .5)) - (bullet.height * .5);
bullet.alive = true;
}
if (this.powerLevel === 2) {
var bullet = this.bulletPool.find(notAlive);
if (!bullet) {
return;
}
bullet.alive = true;
var bullet2 = this.bulletPool.find(notAlive);
if (!bullet) {
return;
}
bullet2.alive = true;
bullet.x = this.x + this.width - bullet.width;
bullet.y = (this.y + (this.height * .5)) - (bullet.height * .5) - 6;
bullet2.x = this.x + this.width - bullet2.width;
bullet2.y = (this.y + (this.height * .5)) - (bullet2.height * .5) + 6;
}
if (this.powerLevel >= 3) {
var bullet = this.bulletPool.find(notAlive);
if (!bullet) {
return;
}
bullet.alive = true;
var bullet2 = this.bulletPool.find(notAlive);
if (!bullet2) {
return;
}
bullet2.alive = true;
var bullet3 = this.bulletPool.find(notAlive);
if (!bullet3) {
return;
}
bullet3.alive = true;
bullet.x = this.x + this.width - bullet.width;
bullet.y = (this.y + (this.height * .5)) - (bullet.height * .5) - 12;
bullet2.x = this.x + this.width - bullet2.width + 8;
bullet2.y = (this.y + (this.height * .5)) - (bullet2.height * .5);
bullet3.x = this.x + this.width - bullet3.width;
bullet3.y = (this.y + (this.height * .5)) - (bullet3.height * .5) + 12;
}
if (this.powerLevel >= 5) {
var bullet = this.bulletPool.find(notAlive);
if (!bullet) {
return;
}
bullet.alive = true;
var bullet2 = this.bulletPool.find(notAlive);
if (!bullet2) {
return;
}
bullet2.alive = true;
bullet.x = this.x + this.width - bullet.width - 8;
bullet.y = (this.y + (this.height * .5)) - (bullet.height * .5) - 24;
bullet2.x = this.x + this.width - bullet2.width - 8;
bullet2.y = (this.y + (this.height * .5)) - (bullet2.height * .5) + 24;
}
}
Player.prototype.render = function(context) {
if (!this.alive) {
return;
}
this.buffer = this.buffer ? this.buffer + 1 : 1;
if(this.buffer && this.buffer == 4) {
this.frame += 1;
if (this.frame >= 10) this.frame = 0;
this.burnFrame += 1;
if (this.burnFrame >= 2) this.burnFrame = 0;
this.buffer = 0;
}
context.drawImage(
this.img, 0, this.frame * 32, 32, 32,
this.x, this.y, this.width, this.height
)
if (this.burning) {
context.drawImage(
this.burnImg, 0, this.burnFrame * 32, 32, 32,
this.x, this.y, this.width, this.height
)
}
this.bulletPool.forEach(function(bullet) {
if (!bullet.alive) {
return false;
}
bullet.render(context);
})
}
function Popcorn(x, y)
{
Ship.call(this, x, y, 32, 32, Popcorn.HEALTH);
this.img = document.createElement('img');
this.img.src = popCornSprite;
this.frames = 12;
this.buffer = 4;
this.speed = Popcorn.SPEED;
this.value = 5;
this.healthMax = Popcorn.HEALTH;
this.reset();
}
Popcorn.prototype = new Ship();
Popcorn.SPEED = 5;
Popcorn.HEALTH = 80;
Popcorn.prototype.reset = function() {
this.x = canvas.width;
this.y = Math.random() * canvas.height - this.height;
this.currentFrame = 0;
this.currentBuffer = 0;
this.alive = false;
this.health = Popcorn.HEALTH;
}
Popcorn.prototype.update = function() {
this.vx = -this.speed;
this.x += this.vx;
if (this.x + this.width <= 0) {
this.reset();
}
}
Popcorn.prototype.render = function(context) {
if (!this.alive) {
return;
}
if (this.currentBuffer === this.buffer) {
this.currentBuffer = 0;
this.currentFrame ++;
if (this.currentFrame === this.frames) {
this.currentFrame = 0;
}
}
context.drawImage(
this.img, 0, this.currentFrame * 32, 32, 32,
this.x, this.y, this.width, this.height
)
context.fillStyle = '#f00';
context.fillRect(this.x, this.y - 2, this.width, 1);
context.fillStyle = '#0f0';
this.perc = this.health/ this.healthMax;
context.fillRect(this.x, this.y - 2, this.width * this.perc , 1)
if (this.hit) {
var tmpOperation = context.globalCompositeOperation
context.globalCompositeOperation = 'color-dodge';
context.drawImage(
this.img, 0, this.currentFrame * 32, 32, 32,
this.x, this.y, this.width, this.height
)
context.drawImage(
this.img, 0, this.currentFrame * 32, 32, 32,
this.x, this.y, this.width, this.height
)
context.globalCompositeOperation = tmpOperation;
this.hit = false;
}
this.currentBuffer++;
}
Game.prototype.update = function() {
this.currentState.update();
}
Game.prototype.render = function(context) {
this.currentState.render(context);
}
Game.prototype.loop = function() {
window.requestAnimationFrame(function(){this.loop()}.bind(this));
now = Date.now();
dt = now - then;
if (dt <= fps) { return }
then = now - (dt % fps);
this.update();
this.render(context);
}
Game.prototype.init = function() {
this.autoShoot = true;
this.setState(this.states.title);
this.currentState.init();
window.requestAnimationFrame(function(){ this.loop() }.bind(this));
}
var game = new Game();
function InputManager() {
this.upPressed = false;
this.downPressed = false;
this.leftPressed = false;
this.rightPressed = false;
this.shooting = false;
this.start = false;
}
InputManager.prototype.handleKey = function(e, state) {
switch(e.keyCode) {
case InputManager.UP:
this.upPressed = state;
break;
case InputManager.DOWN:
this.downPressed = state;
break;
case InputManager.LEFT:
this.leftPressed = state;
break;
case InputManager.RIGHT:
this.rightPressed = state;
break;
case InputManager.SHOOT:
this.shooting = state;
break;
case InputManager.RESET:
game.reset();
game.setState(game.states.title);
game.currentState.init();
break;
case InputManager.START:
this.start = state;
break;
}
}
InputManager.UP = UP;
InputManager.DOWN = DOWN;
InputManager.LEFT = LEFT;
InputManager.RIGHT = RIGHT;
InputManager.SHOOT = SHOOT;
InputManager.RESET = RESET;
InputManager.START = START;
var inputManager = new InputManager();
window.addEventListener(
'keydown',
function(e) {
game.autoShoot = false;
this.handleKey(e, true)
}.bind(inputManager)
);
window.addEventListener(
'keyup',
function(e){
this.handleKey(e, false)
}.bind(inputManager)
);
game.init();
* {
margin: 0;
padding: 0;
}
body {
font-size: 24px;
}
#viewport {
background: #020408;
display: block;
width: 100%;
height: 100%;
image-rendering: crisp-edges;
image-rendering: pixelated;
}
.state-ui-container {
display: flex;
flex-direction: row;
position: absolute;
justify-content: left;
align-items: left;
}
.ui-text {
user-select: none;
font-family: arial;
font-size: 1em;
font-weight: bold;
font-variant-numeric: tabular-nums;
margin: 10px;
color: #e4e4e4;
text-shadow: 0 2px 2px rgba(125,0,0,.51),
0 0 10px rgba(255,0,255,1),
0 0 10px rgba(255,0,255,1);
text-align: left;
}
#score {
left: 0;
}
#lives {
right: 0;
}
.ui-text--heading {
font-size: 4em;
}
.state-ui-container {
width: 100%;
display: none;
height: 100%;
justify-content: center;
}
.console {
align-self: center;
}
.banner {
align-self: flex-start;
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment