import Profectus from "components/Profectus.vue"; import Spacer from "components/layout/Spacer.vue"; import { jsx } from "features/feature"; import { createResource, trackBest, trackOOMPS, trackTotal } from "features/resources/resource"; import { branchedResetPropagation, createTree, GenericTree } from "features/trees/tree"; import { globalBus } from "game/events"; import { createLayer, GenericLayer, setupLayerModal } from "game/layers"; import player, { PlayerData } from "game/player"; import Decimal, { DecimalSource, format, formatTime } from "util/bignum"; import { render } from "util/vue"; import { computed, toRaw } from "vue"; import a from "./layers/aca/a"; import c from "./layers/aca/c"; import f from "./layers/aca/f"; /** * @hidden */ export const main = createLayer("main", () => { const points = createResource(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(() => ( <>
Game Paused
Dev Speed: {format(player.devSpeed || 0)}x
Offline Time: {formatTime(player.offlineTime || 0)}
You have

{format(points.value)}

points
({oomps.value})
{render(modal)} {render(tree)} )), points, best, total, oomps, tree, showAchievements: openModal }; }); export const getInitialLayers = ( /* eslint-disable-next-line @typescript-eslint/no-unused-vars */ player: Partial ): Array => [main, f, c, a]; export const hasWon = computed(() => { return Decimal.gt(main.points.value, 25); }); /* eslint-disable @typescript-eslint/no-unused-vars */ export function fixOldSave( oldVersion: string | undefined, player: Partial // eslint-disable-next-line @typescript-eslint/no-empty-function ): void {} /* eslint-enable @typescript-eslint/no-unused-vars */