User prompt
Fix Bug: 'TypeError: undefined is not an object (evaluating 'sameTypeBubbles.length')' in this line: 'if (sameTypeBubbles.length >= 3) {' Line Number: 125
User prompt
You should be game over if there is not three connected bubbles in the game
User prompt
Test if the game has no possible moves, if so call gameover
User prompt
Add 10 colors in total, make sure they are all bright
User prompt
Change the tint colors to use a color array
User prompt
Only use bright colors for ball types, also save these from an array
User prompt
Add 10 different ball types
User prompt
Add a new method to Game that checks if the top row has an empty space, if so insert a new bubble here.
User prompt
Bubbles added by spawnBubble should fade in
User prompt
Call spawnBubble at bottom of tick
User prompt
Add a method to Game class that adds bubbles to the top row, if no bubbles currently exist there
User prompt
remove self.fillTopRow(bubbles); from pop
User prompt
Move the fillTopRow into the Game class
User prompt
Fix Bug: 'ReferenceError: Can't find variable: gameBoard' in this line: 'gameBoard.addChild(newBubble);' Line Number: 12
User prompt
Call fillTopRow at the bottom of tick
User prompt
Insert a new method in Game that inserts new bubbles in the top row, if there is no bubble there currently
User prompt
After removing bubbles, check if there is free spaces at the top row. If so insert bubbles here
User prompt
Insert new bubbles at the top row, if there is no bubble there
User prompt
Make ball dropping twice as fast
User prompt
Make acceleration faster on balls falling down
User prompt
Make sure the Y can never be larger than target Y
User prompt
Animate y position y accelerating y, until y is equal or larger than the target. Then stop acceleration and set Y to target Y
User prompt
In move calculate where the bubble should be, vs where it is. If the bubble is not where it should be, animate it to where it should be
User prompt
Don't update bubble physical position when moving to a new position in array
User prompt
Move the changes check inside a tick handler
var Bubble = Container.expand(function (bubbles) {
	var self = Container.call(this);
	self.arrayX = 0;
	self.arrayY = 0;
	self.type = Math.floor(Math.random() * 5);
	var bubbleGraphics = self.createAsset('bubble', 'Bubble Graphics', .5, .5);
	switch (self.type) {
		case 0:
			bubbleGraphics.tint = 0xFF0000;
			break;
		case 1:
			bubbleGraphics.tint = 0x00FF00;
			break;
		case 2:
			bubbleGraphics.tint = 0x0000FF;
			break;
		case 3:
			bubbleGraphics.tint = 0xFFFF00;
			break;
		case 4:
			bubbleGraphics.tint = 0xFF00FF;
			break;
	}
	self.move = function () {
		if (self.arrayY < bubbles[0].length - 1 && !bubbles[self.arrayX][self.arrayY + 1]) {
			bubbles[self.arrayX][self.arrayY] = null;
			self.arrayY++;
			bubbles[self.arrayX][self.arrayY] = self;
			self.y += self.height + 4;
			return true;
		}
		return false;
	};
	self.on('down', function () {
		this.pop(bubbles);
	});
	self.pop = function () {
		var sameTypeBubbles = [];
		var stack = [this];
		while (stack.length) {
			var currentBubble = stack.pop();
			sameTypeBubbles.push(currentBubble);
			var neighbors = this.getNeighbors(currentBubble);
			for (var i = 0; i < neighbors.length; i++) {
				if (neighbors[i].type === this.type && !sameTypeBubbles.includes(neighbors[i]) && !stack.includes(neighbors[i])) {
					stack.push(neighbors[i]);
				}
			}
		}
		if (sameTypeBubbles.length >= 3) {
			for (var i = 0; i < sameTypeBubbles.length; i++) {
				sameTypeBubbles[i].destroy();
			}
		}
	};
	self.getNeighbors = function (bubble) {
		var neighbors = [];
		var positions = [[-1, 0], [1, 0], [0, -1], [0, 1]];
		for (var i = 0; i < positions.length; i++) {
			var x = positions[i][0] + bubble.arrayX;
			var y = positions[i][1] + bubble.arrayY;
			if (x >= 0 && x < bubbles.length && y >= 0 && y < bubbles[0].length && bubbles[x][y]) {
				neighbors.push(bubbles[x][y]);
			}
		}
		return neighbors;
	};
});
var Game = Container.expand(function () {
	var self = Container.call(this);
	var bubbles = new Array(9).fill().map(() => new Array(9).fill(null));
	var gameBoard = new Container();
	gameBoard.x = 61;
	gameBoard.y = 61;
	self.addChild(gameBoard);
	var spawnBubble = function () {
		for (var i = 0; i < 9; i++) {
			for (var j = 0; j < 9; j++) {
				var newBubble = new Bubble(bubbles);
				newBubble.arrayX = i;
				newBubble.arrayY = j;
				newBubble.x = i * (newBubble.width + 4) + newBubble.width / 2;
				newBubble.y = j * (newBubble.height + 4) + newBubble.height / 2;
				bubbles[i][j] = newBubble;
				gameBoard.addChild(newBubble);
			}
		}
	};
	spawnBubble();
	var changes = false;
	LK.on('tick', function () {
		do {
			changes = false;
			for (var i = bubbles.length - 1; i >= 0; i--) {
				for (var j = bubbles[i].length - 1; j >= 0; j--) {
					if (bubbles[i][j]) {
						if (bubbles[i][j].move()) {
							changes = true;
						}
						if (bubbles[i][j] && !bubbles[i][j].parent) {
							bubbles[i][j] = null;
						} else if (bubbles[i][j] && bubbles[i][j].arrayY < bubbles[0].length - 1 && !bubbles[i][j].parent) {
							bubbles[i][j] = null;
						}
					}
				}
			}
		} while (changes);
	});
});
 var Bubble = Container.expand(function (bubbles) {
	var self = Container.call(this);
	self.arrayX = 0;
	self.arrayY = 0;
	self.type = Math.floor(Math.random() * 5);
	var bubbleGraphics = self.createAsset('bubble', 'Bubble Graphics', .5, .5);
	switch (self.type) {
		case 0:
			bubbleGraphics.tint = 0xFF0000;
			break;
		case 1:
			bubbleGraphics.tint = 0x00FF00;
			break;
		case 2:
			bubbleGraphics.tint = 0x0000FF;
			break;
		case 3:
			bubbleGraphics.tint = 0xFFFF00;
			break;
		case 4:
			bubbleGraphics.tint = 0xFF00FF;
			break;
	}
	self.move = function () {
		if (self.arrayY < bubbles[0].length - 1 && !bubbles[self.arrayX][self.arrayY + 1]) {
			bubbles[self.arrayX][self.arrayY] = null;
			self.arrayY++;
			bubbles[self.arrayX][self.arrayY] = self;
			self.y += self.height + 4;
			return true;
		}
		return false;
	};
	self.on('down', function () {
		this.pop(bubbles);
	});
	self.pop = function () {
		var sameTypeBubbles = [];
		var stack = [this];
		while (stack.length) {
			var currentBubble = stack.pop();
			sameTypeBubbles.push(currentBubble);
			var neighbors = this.getNeighbors(currentBubble);
			for (var i = 0; i < neighbors.length; i++) {
				if (neighbors[i].type === this.type && !sameTypeBubbles.includes(neighbors[i]) && !stack.includes(neighbors[i])) {
					stack.push(neighbors[i]);
				}
			}
		}
		if (sameTypeBubbles.length >= 3) {
			for (var i = 0; i < sameTypeBubbles.length; i++) {
				sameTypeBubbles[i].destroy();
			}
		}
	};
	self.getNeighbors = function (bubble) {
		var neighbors = [];
		var positions = [[-1, 0], [1, 0], [0, -1], [0, 1]];
		for (var i = 0; i < positions.length; i++) {
			var x = positions[i][0] + bubble.arrayX;
			var y = positions[i][1] + bubble.arrayY;
			if (x >= 0 && x < bubbles.length && y >= 0 && y < bubbles[0].length && bubbles[x][y]) {
				neighbors.push(bubbles[x][y]);
			}
		}
		return neighbors;
	};
});
var Game = Container.expand(function () {
	var self = Container.call(this);
	var bubbles = new Array(9).fill().map(() => new Array(9).fill(null));
	var gameBoard = new Container();
	gameBoard.x = 61;
	gameBoard.y = 61;
	self.addChild(gameBoard);
	var spawnBubble = function () {
		for (var i = 0; i < 9; i++) {
			for (var j = 0; j < 9; j++) {
				var newBubble = new Bubble(bubbles);
				newBubble.arrayX = i;
				newBubble.arrayY = j;
				newBubble.x = i * (newBubble.width + 4) + newBubble.width / 2;
				newBubble.y = j * (newBubble.height + 4) + newBubble.height / 2;
				bubbles[i][j] = newBubble;
				gameBoard.addChild(newBubble);
			}
		}
	};
	spawnBubble();
	var changes = false;
	LK.on('tick', function () {
		do {
			changes = false;
			for (var i = bubbles.length - 1; i >= 0; i--) {
				for (var j = bubbles[i].length - 1; j >= 0; j--) {
					if (bubbles[i][j]) {
						if (bubbles[i][j].move()) {
							changes = true;
						}
						if (bubbles[i][j] && !bubbles[i][j].parent) {
							bubbles[i][j] = null;
						} else if (bubbles[i][j] && bubbles[i][j].arrayY < bubbles[0].length - 1 && !bubbles[i][j].parent) {
							bubbles[i][j] = null;
						}
					}
				}
			}
		} while (changes);
	});
});