mirror of
https://github.com/MartinKral/Slash-The-Hordes
synced 2024-12-25 11:18:54 +00:00
Upgrade indicator
This commit is contained in:
parent
aa26876346
commit
af5db18bfb
File diff suppressed because it is too large
Load Diff
@ -2,7 +2,7 @@ import { sys } from "cc";
|
|||||||
import { UserData } from "../Game/Data/UserData";
|
import { UserData } from "../Game/Data/UserData";
|
||||||
|
|
||||||
export class SaveSystem {
|
export class SaveSystem {
|
||||||
private userDataIdentifier = "user-dse";
|
private userDataIdentifier = "user-dseeee";
|
||||||
public save(userData: UserData): void {
|
public save(userData: UserData): void {
|
||||||
sys.localStorage.setItem(this.userDataIdentifier, JSON.stringify(userData));
|
sys.localStorage.setItem(this.userDataIdentifier, JSON.stringify(userData));
|
||||||
}
|
}
|
||||||
|
@ -1,9 +1,9 @@
|
|||||||
import { Canvas, Component, Label, _decorator } from "cc";
|
import { approx, Canvas, Component, Label, Node, _decorator } from "cc";
|
||||||
import { AppRoot } from "../AppRoot/AppRoot";
|
import { AppRoot } from "../AppRoot/AppRoot";
|
||||||
import { requireAppRootAsync } from "../AppRoot/AppRootUtils";
|
import { requireAppRootAsync } from "../AppRoot/AppRootUtils";
|
||||||
import { ModalWindowManager } from "../Services/ModalWindowSystem/ModalWindowManager";
|
import { MetaUpgradeSettings } from "../Game/Data/GameSettings";
|
||||||
|
import { MetaUpgradesData } from "../Game/Data/UserData";
|
||||||
import { UIButton } from "../Services/UI/Button/UIButton";
|
import { UIButton } from "../Services/UI/Button/UIButton";
|
||||||
import { OpenCloseAnimator } from "../Utils/OpenCloseAnimator";
|
|
||||||
import { GameRunner } from "./GameRunner";
|
import { GameRunner } from "./GameRunner";
|
||||||
import { MenuModalLauncher } from "./ModalWindows/MenuModalLauncher";
|
import { MenuModalLauncher } from "./ModalWindows/MenuModalLauncher";
|
||||||
|
|
||||||
@ -13,6 +13,7 @@ const { ccclass, property } = _decorator;
|
|||||||
export class Menu extends Component {
|
export class Menu extends Component {
|
||||||
@property(UIButton) private playBtn: UIButton;
|
@property(UIButton) private playBtn: UIButton;
|
||||||
@property(UIButton) private upgradeBtn: UIButton;
|
@property(UIButton) private upgradeBtn: UIButton;
|
||||||
|
@property(Node) private upgradeAvailableIndicator: Node;
|
||||||
@property(UIButton) private audioSettingsBtn: UIButton;
|
@property(UIButton) private audioSettingsBtn: UIButton;
|
||||||
@property(Canvas) private menuCanvas: Canvas;
|
@property(Canvas) private menuCanvas: Canvas;
|
||||||
@property(Label) private highscoreLabel: Label;
|
@property(Label) private highscoreLabel: Label;
|
||||||
@ -30,6 +31,35 @@ export class Menu extends Component {
|
|||||||
this.menuModalLauncher = new MenuModalLauncher(AppRoot.Instance.ModalWindowManager);
|
this.menuModalLauncher = new MenuModalLauncher(AppRoot.Instance.ModalWindowManager);
|
||||||
|
|
||||||
this.highscoreLabel.string = `Highscore: ${Math.floor(AppRoot.Instance.LiveUserData.game.highscore)}`;
|
this.highscoreLabel.string = `Highscore: ${Math.floor(AppRoot.Instance.LiveUserData.game.highscore)}`;
|
||||||
|
|
||||||
|
this.updateUpgradeIndicator();
|
||||||
|
}
|
||||||
|
|
||||||
|
private updateUpgradeIndicator(): void {
|
||||||
|
this.upgradeAvailableIndicator.active = this.isUpgradeAffordable();
|
||||||
|
}
|
||||||
|
|
||||||
|
private isUpgradeAffordable(): boolean {
|
||||||
|
const goldCoins: number = AppRoot.Instance.LiveUserData.game.goldCoins;
|
||||||
|
const metaUpgrades: MetaUpgradesData = AppRoot.Instance.LiveUserData.game.metaUpgrades;
|
||||||
|
|
||||||
|
const metaUpgradesSettings = AppRoot.Instance.Settings.metaUpgrades;
|
||||||
|
|
||||||
|
const costs: number[] = [];
|
||||||
|
this.tryPushLowestCost(metaUpgrades.goldGathererLevel, metaUpgradesSettings.goldGatherer, costs);
|
||||||
|
this.tryPushLowestCost(metaUpgrades.healthLevel, metaUpgradesSettings.health, costs);
|
||||||
|
this.tryPushLowestCost(metaUpgrades.movementSpeedLevel, metaUpgradesSettings.movementSpeed, costs);
|
||||||
|
this.tryPushLowestCost(metaUpgrades.overallDamageLevel, metaUpgradesSettings.overallDamage, costs);
|
||||||
|
this.tryPushLowestCost(metaUpgrades.projectilePiercingLevel, metaUpgradesSettings.projectilePiercing, costs);
|
||||||
|
this.tryPushLowestCost(metaUpgrades.xpGathererLevel, metaUpgradesSettings.xpGatherer, costs);
|
||||||
|
|
||||||
|
return 0 < costs.length ? Math.min(...costs) <= goldCoins : false;
|
||||||
|
}
|
||||||
|
|
||||||
|
private tryPushLowestCost(upgradeLevel: number, metaUpgradeSettings: MetaUpgradeSettings, costs: number[]): void {
|
||||||
|
if (upgradeLevel < metaUpgradeSettings.costs.length) {
|
||||||
|
costs.push(metaUpgradeSettings.costs[upgradeLevel]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private startGame(): void {
|
private startGame(): void {
|
||||||
@ -37,8 +67,9 @@ export class Menu extends Component {
|
|||||||
GameRunner.Instance.playGame();
|
GameRunner.Instance.playGame();
|
||||||
}
|
}
|
||||||
|
|
||||||
private openUpgradesWindow(): void {
|
private async openUpgradesWindow(): Promise<void> {
|
||||||
this.menuModalLauncher.openUpgradesWindow();
|
await this.menuModalLauncher.openUpgradesWindow();
|
||||||
|
this.updateUpgradeIndicator();
|
||||||
}
|
}
|
||||||
|
|
||||||
private openAudioSettingsWindow(): void {
|
private openAudioSettingsWindow(): void {
|
||||||
|
Loading…
Reference in New Issue
Block a user