- Table of Contents
- Getting Started
- Architecture
- Balloon spawn chances
- Inheritance Tree
- Abstract balloon class
- Balloons
Clone the repository:
git clone https://github.com/SimonStnn/pop-a-loon
Install the dependencies:
npm install
Building for development can be done with the dev:{browser}
script. Replace {browser}
with the browser you want to build for. The available options are chrome
and firefox
.
Tip
See the Load the extension to chrome and Load the extension to firefox sections for instructions on how to load the extension in the browser.
Important
This will call the dev:chrome:noremote script.
To build for Chrome:
npm run dev:chrome
This will build the extension in development mode for chrome. You can also include the --watch
flag to automatically rebuild the extension when files change.
npm run dev:chrome -- --watch
To build for Chrome without a remote server1:
npm run dev:chrome:noremote
This will build the extension in development mode for chrome without a remote server. You can also include the --watch
flag to automatically rebuild the extension when files change.
npm run dev:chrome:noremote -- --watch
Important
This will connect to a pop-a-loon-backend server which is expected to be running on http://localhost:3000
.
To build for Chrome with a remote server:
npm run dev:chrome:remote
Important
This will call the dev:firefox:noremote script.
To build for Firefox:
npm run dev:firefox
This will build the extension in development mode for firefox. You can also include the --watch
flag to automatically rebuild the extension when files change.
npm run dev:firefox -- --watch
To build for Firefox without a remote server1:
npm run dev:firefox:noremote
This will build the extension in development mode for firefox without a remote server. You can also include the --watch
flag to automatically rebuild the extension when files change.
npm run dev:firefox:noremote -- --watch
Important
This will connect to a pop-a-loon-backend server which is expected to be running on http://localhost:3000
.
To build for Firefox with a remote server:
npm run dev:firefox:remote
This will build the extension in development mode for firefox with a remote server. You can also include the --watch
flag to automatically rebuild the extension when files change.
npm run dev:firefox:remote -- --watch
The extension can be loaded in the browser by following the steps below:
-
Open the Extension Management page by navigating to
chrome://extensions
.Don't forget to enable Developer mode in the top right corner.
-
Click the
Load unpacked
button and select thedist/
directory. -
The extension should now be loaded and you can see the icon in the browser toolbar.
-
Pin the extension to the toolbar for easy access.
The extension can be loaded in the browser by following the steps below:
- Open the Add-ons page by navigating to
about:addons
. - Click the
Extensions
tab on the left. - Click the
Manage your extensions
button. - Click the
Debug Add-ons
button. - Click the
Load Temporary Add-on
button and select themanifest.json
file in thedist/
directory. - The extension should now be loaded and you can see the icon in the browser toolbar.
- Pin the extension to the toolbar for easy access.
- Open the project in Visual Studio Code.
- Go to the Run view (Ctrl+Shift+D).
- Select
Launch Chrome
orLaunch Firefox
from the dropdown at the top of the Run view. - Press the Start Debugging button (F5).
This will start the development server (if it's not already running) and open a new browser instance with debugging enabled.
To build the extension for production, use the build:{browser}
script. Replace {browser}
with the browser you want to build for. The available options are chrome
and firefox
. You can also include :zip
to create a zip file of the extension.
To build for Chrome:
npm run build:chrome
This will build the extension in production mode for chrome. You can also include the :zip
flag to create a zip file of the extension.
npm run build:chrome:zip
The zip file will be created in the build/
directory.
To build for Firefox:
npm run build:firefox
This will build the extension in production mode for firefox. You can also include the :zip
flag to create a zip file of the extension.
npm run build:firefox:zip
This will build the extension in production for all browsers and include a zip file of the source code.
npm run build:all:zip
This will create a zip file of the source code. The zip file will be created in the build/
directory with the name source-v{version}.zip
.
npm run zip:source
The zip file will be created in the build/
directory.
Refer to adding a balloon for instructions on how to add a new balloon to the extension.
Note
Read the Architecture document for a more detailed explanation of the architecture.
pie showData
title Balloon spawn chances
"Default" : 0.65
"Splitter": 0.10
"Confetti" : 0.10
"Fast": 0.10
"Gold": 0.05
"Ghost": 0.10
classDiagram
direction BT
class Balloon { <<Abstract>> }
Default --|> Balloon
Confetti --|> Default
Fast --|> Default
Gold --|> Default
Ghost --|> Default
Splitter --|> Default
The abstract balloon class is the base class for all balloons.
classDiagram
direction LR
class Balloon {
<<Abstract>>
+name: string*
+build() void*
+element: HTMLDivElement
+constructor()
+isRising() boolean
+rise() void
+remove() void
+pop() void
}
The class serves as a base class for each balloon in pop-a-loon, providing essential functionality that must operate from this class.
Important
The class has the following abstract properties and methods:
name
: The name of the balloon. Should be the same as the name of the class, but in lowercase.build()
: Is called when the balloon should be built. In this method the class should for example add the styling and balloon image to the balloon element.
These properties and methods must be implemented in the child classes.
Important
The element
is the html element that will be added to the DOM after the balloon is built.