2022-03-06 04:51:12 +00:00
|
|
|
import Profectus from "components/Profectus.vue";
|
2022-03-04 03:39:48 +00:00
|
|
|
import Spacer from "components/layout/Spacer.vue";
|
|
|
|
import { jsx } from "features/feature";
|
|
|
|
import { createResource, trackBest, trackOOMPS, trackTotal } from "features/resources/resource";
|
2022-06-27 00:17:22 +00:00
|
|
|
import type { GenericTree } from "features/trees/tree";
|
|
|
|
import { branchedResetPropagation, createTree } from "features/trees/tree";
|
2022-03-04 03:39:48 +00:00
|
|
|
import { globalBus } from "game/events";
|
2022-06-27 00:17:22 +00:00
|
|
|
import type { GenericLayer } from "game/layers";
|
2022-06-27 03:16:00 +00:00
|
|
|
import { setupLayerModal } from "game/layers";
|
2022-06-27 00:17:22 +00:00
|
|
|
import { createLayer } from "game/layers";
|
|
|
|
import type { PlayerData } from "game/player";
|
|
|
|
import player from "game/player";
|
|
|
|
import type { DecimalSource } from "util/bignum";
|
|
|
|
import Decimal, { format, formatTime } from "util/bignum";
|
2022-03-04 03:39:48 +00:00
|
|
|
import { render } from "util/vue";
|
2022-02-28 00:11:01 +00:00
|
|
|
import { computed, toRaw } from "vue";
|
|
|
|
import a from "./layers/aca/a";
|
|
|
|
import c from "./layers/aca/c";
|
|
|
|
import f from "./layers/aca/f";
|
|
|
|
|
2022-03-08 06:25:08 +00:00
|
|
|
/**
|
|
|
|
* @hidden
|
|
|
|
*/
|
2022-04-11 00:14:49 +00:00
|
|
|
export const main = createLayer("main", () => {
|
2022-02-28 00:11:01 +00:00
|
|
|
const points = createResource<DecimalSource>(10);
|
|
|
|
const best = trackBest(points);
|
|
|
|
const total = trackTotal(points);
|
|
|
|
|
|
|
|
const pointGain = computed(() => {
|
|
|
|
if (!c.generatorUpgrade.bought.value) return new Decimal(0);
|
|
|
|
let gain = new Decimal(3.19);
|
|
|
|
if (c.lollipopMultiplierUpgrade.bought.value)
|
|
|
|
gain = gain.times(c.lollipopMultiplierEffect.value);
|
|
|
|
return gain;
|
|
|
|
});
|
|
|
|
globalBus.on("update", diff => {
|
|
|
|
points.value = Decimal.add(points.value, Decimal.times(pointGain.value, diff));
|
|
|
|
});
|
|
|
|
const oomps = trackOOMPS(points, pointGain);
|
|
|
|
|
|
|
|
const { openModal, modal } = setupLayerModal(a);
|
|
|
|
|
|
|
|
// Note: Casting as generic tree to avoid recursive type definitions
|
|
|
|
const tree = createTree(() => ({
|
|
|
|
nodes: [[c.treeNode], [f.treeNode, c.spook]],
|
|
|
|
leftSideNodes: [a.treeNode, c.h],
|
|
|
|
branches: [
|
|
|
|
{
|
|
|
|
startNode: f.treeNode,
|
|
|
|
endNode: c.treeNode,
|
|
|
|
stroke: "blue",
|
|
|
|
"stroke-width": "25px",
|
|
|
|
style: {
|
|
|
|
filter: "blur(5px)"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
],
|
|
|
|
onReset() {
|
|
|
|
points.value = toRaw(this.resettingNode.value) === toRaw(c.treeNode) ? 0 : 10;
|
|
|
|
best.value = points.value;
|
|
|
|
total.value = points.value;
|
|
|
|
},
|
|
|
|
resetPropagation: branchedResetPropagation
|
|
|
|
})) as GenericTree;
|
|
|
|
|
|
|
|
// Note: layers don't _need_ a reference to everything,
|
|
|
|
// but I'd recommend it over trying to remember what does and doesn't need to be included.
|
|
|
|
// Officially all you need are anything with persistency or that you want to access elsewhere
|
|
|
|
return {
|
|
|
|
name: "Tree",
|
|
|
|
display: jsx(() => (
|
|
|
|
<>
|
2022-04-24 03:13:56 +00:00
|
|
|
{player.devSpeed === 0 ? <div>Game Paused</div> : null}
|
|
|
|
{player.devSpeed && player.devSpeed !== 1 ? (
|
2022-05-11 02:01:57 +00:00
|
|
|
<div>Dev Speed: {format(player.devSpeed)}x</div>
|
2022-04-24 03:13:56 +00:00
|
|
|
) : null}
|
2022-05-11 02:01:57 +00:00
|
|
|
{player.offlineTime ? (
|
|
|
|
<div>Offline Time: {formatTime(player.offlineTime)}</div>
|
2022-04-24 03:13:56 +00:00
|
|
|
) : null}
|
2022-02-28 00:11:01 +00:00
|
|
|
<div>
|
2022-04-24 03:13:56 +00:00
|
|
|
{Decimal.lt(points.value, "1e1000") ? <span>You have </span> : null}
|
2022-02-28 00:11:01 +00:00
|
|
|
<h2>{format(points.value)}</h2>
|
2022-04-24 03:13:56 +00:00
|
|
|
{Decimal.lt(points.value, "1e1e6") ? <span> points</span> : null}
|
2022-02-28 00:11:01 +00:00
|
|
|
</div>
|
2022-04-24 03:13:56 +00:00
|
|
|
{Decimal.gt(pointGain.value, 0) ? <div>({oomps.value})</div> : null}
|
2022-02-28 00:11:01 +00:00
|
|
|
<Spacer />
|
|
|
|
<button onClick={openModal}>open achievements</button>
|
|
|
|
{render(modal)}
|
|
|
|
{render(tree)}
|
|
|
|
<Profectus height="200px" style="margin: 10px auto; display: block" />
|
|
|
|
</>
|
|
|
|
)),
|
|
|
|
points,
|
|
|
|
best,
|
|
|
|
total,
|
|
|
|
oomps,
|
|
|
|
tree,
|
|
|
|
showAchievements: openModal
|
|
|
|
};
|
|
|
|
});
|
|
|
|
|
2022-07-10 06:44:45 +00:00
|
|
|
/**
|
|
|
|
* Given a player save data object being loaded, return a list of layers that should currently be enabled.
|
|
|
|
* If your project does not use dynamic layers, this should just return all layers.
|
|
|
|
*/
|
2022-02-28 00:11:01 +00:00
|
|
|
export const getInitialLayers = (
|
|
|
|
/* eslint-disable-next-line @typescript-eslint/no-unused-vars */
|
|
|
|
player: Partial<PlayerData>
|
|
|
|
): Array<GenericLayer> => [main, f, c, a];
|
|
|
|
|
2022-07-10 06:44:45 +00:00
|
|
|
/**
|
|
|
|
* A computed ref whose value is true whenever the game is over.
|
|
|
|
*/
|
2022-02-28 00:11:01 +00:00
|
|
|
export const hasWon = computed(() => {
|
|
|
|
return Decimal.gt(main.points.value, 25);
|
|
|
|
});
|
|
|
|
|
2022-07-10 06:44:45 +00:00
|
|
|
/**
|
|
|
|
* Given a player save data object being loaded with a different version, update the save data object to match the structure of the current version.
|
|
|
|
* @param oldVersion The version of the save being loaded in
|
|
|
|
* @param player The save data being loaded in
|
|
|
|
*/
|
2022-02-28 00:11:01 +00:00
|
|
|
/* eslint-disable @typescript-eslint/no-unused-vars */
|
|
|
|
export function fixOldSave(
|
|
|
|
oldVersion: string | undefined,
|
|
|
|
player: Partial<PlayerData>
|
|
|
|
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
|
|
): void {}
|
|
|
|
/* eslint-enable @typescript-eslint/no-unused-vars */
|